

# SN8P2700A 系列

## 用户参考手册

Version 1.1

SN8P2704A SN8P2705A SN8P2706A SN8P2707A SN8P2708A

# SONIX 8 位单片机

SONiX 公司保留对以下所有产品在可靠性,功能和设计方面的改进作进一步说明的权利。SONiX 不承担由本手册所涉及的产品或电路的运用和使用所引起的任何责任,SONiX 的产品不是专门设计来应用于外科植入、生命维持和任何SONiX 产品的故障会对个体造成伤害甚至死亡的领域。如果将 SONiX 的产品应用于上述领域,即使这些是由 SONiX 在产品设计和制造上的疏忽引起的,用户应赔偿所有费用、损失、合理的人身伤害或死亡所直接或间接产生的律师费用,并且用户保证 SONiX 及其雇员、子公司、分支机构和销售商与上述事宜无关。



# 修改记录

| 版本      | 日期     | 说明                          |
|---------|--------|-----------------------------|
| VER 1.0 | 2008.2 | 初版。                         |
| VER 1.0 | 2008.5 | 修改烧录信息章节内容。                 |
| VER 1.1 | 2011.6 | 1、添加 SN8P2704AX SSOP 的封装形式。 |
|         |        | 2、修改 SIO SCK 频率。            |



# 目 录

|   |             |                       | _  |
|---|-------------|-----------------------|----|
| 1 | 产品管         | 5介                    | 6  |
|   | 1.1         |                       |    |
|   | 1.2         | 系统框图                  |    |
|   | 1.3         | 引脚配置                  |    |
|   |             |                       |    |
|   | 1.4         | 引脚说明                  |    |
|   | 1.5         | 引脚电路结构图               |    |
| 2 | 中央処         | b理器(CPU)              | 14 |
|   | 2.1         | 存储器                   | 14 |
|   | 2.1.1       | 程序存储器(ROM)            |    |
|   | 2.1.2       | 编译选项表(CODE OPTION)    |    |
|   | 2.1.2       | 数据存储器(RAM)            |    |
|   |             |                       |    |
|   | 2.1.4       | 系统寄存器                 |    |
|   |             | 寻址模式                  |    |
|   | 2.2.1       | 立即寻址                  |    |
|   | 2.2.2       | 直接寻址                  | 32 |
|   | 2.2.3       | 间接寻址                  | 32 |
|   | 2.3         | 堆栈                    | 33 |
|   | 2.3.1       | 概述                    | 33 |
|   | 2.3.2       | 堆栈寄存器                 |    |
|   | 2.3.3       | 堆栈操作举例                |    |
| 3 |             | <b>华仪</b> 床仆宁 <u></u> |    |
| 9 | 夏型 .<br>3.1 | 概述                    |    |
|   |             |                       |    |
|   | 3.2         | 上电复位                  |    |
|   | 3.3         | 看门狗复位                 |    |
|   | 3.4         | 掉电复位                  | 38 |
|   | 3.4.1       | 概述                    | 38 |
|   | 3.4.2       | 系统工作电压                | 38 |
|   | 3.4.3       | 掉电复位性能改进              |    |
|   |             | 外部复位                  |    |
|   | 3.6         | 外部复位电路                |    |
|   | 3.6.1       | 基本 <b>RC</b> 复位电路     |    |
|   |             |                       |    |
|   | 3.6.2       | 二极管及RC复位电路            |    |
|   | 3.6.3       | 稳压二极管复位电路             |    |
|   | 3.6.4       | 电压偏移复位电路              |    |
|   | 3.6.5       | 外部IC复位                |    |
| 4 | 系统印         | 寸钟                    |    |
|   | 4.1         | 概述                    | 44 |
|   | 4.2         | 系统时钟框图                | 44 |
|   | 4.3         | OSCM寄存器               |    |
|   | 4.4         | 系统高速时钟                |    |
|   | 4.4.1       |                       |    |
|   | 4.4.1       | 系统低速时钟                |    |
|   | _           |                       |    |
| F | 4.5.1       | 系统时钟测试                |    |
| 5 |             | [作模式                  |    |
|   | 5.1         | 概述                    |    |
|   | 5.2         | 系统模式切换                | 50 |
|   | 5.3         | 系统唤醒                  | 51 |
|   | 5.3.1       | 概述                    | 51 |
|   | 5.3.2       | 唤醒时间                  | 51 |
|   | 5.3.3       | P1W唤醒功能控制寄存器          | 51 |
| 6 |             | 1100人在为1011时间11加      |    |
| • | 6.1         | 概述                    |    |
|   | 6.2         |                       | _  |
|   |             | 中断使能寄存器INTEN          |    |
|   | 6.3         | 中断请求寄存器INTRQ          |    |
|   | 6.4         | GIE全局中断               |    |
|   | 6.5         | PUSH,POP处理            |    |
|   | 6.6         | INTO (P0.0) 中断        |    |
|   | 6.7         | INT1 (P0.1) 中断        | 57 |
|   |             |                       |    |





|     | 6.8            | INT2 (P0.2) 中断    |      |
|-----|----------------|-------------------|------|
|     | 6.9            | TO 中断             |      |
|     |                | TC0 中断            |      |
|     |                | TC1 中断            |      |
|     |                | SIO中断             |      |
|     |                | ADC中断             |      |
| 7   | 6.14           | 多中断操作举例           |      |
| 1/  |                |                   |      |
|     |                | VO口上拉电阻           |      |
|     | 7.2            | VO口上拉电阻           |      |
|     |                | VO海极开路寄存器         |      |
|     |                | P4 与ADC共用引脚       |      |
| 8   | -              | B                 |      |
| •   | 8.1            | 看门狗定时器            |      |
|     | 8.2            | 定时器T0             |      |
|     | 8.2.1          | 概述                |      |
|     | 8.2.2          | TOM模式寄存器          |      |
|     | 8.2.3          | TOC计数寄存器          |      |
|     | 8.2.4          | TO 操作流程           |      |
|     | 8.2.5          | T0 定时器的注意事项       | .72  |
|     | 8.3            | 定时/计数器TC0         | . 73 |
|     | 8.3.1          | 概述                | . 73 |
|     | 8.3.2          | TC0M模式寄存器         | . 74 |
|     | 8.3.3          | TC0C计数寄存器         | . 75 |
|     | 8.3.4          | TC0R自动装载寄存器       |      |
|     | 8.3.5          | TC0 时钟频率输出(蜂鸣器输出) |      |
|     | 8.3.6          | TC0 定时器操作流程       |      |
|     | 8.3.7          | TC0 定时器注意事项       |      |
|     | 8.4            | 定时/计数器TC1         |      |
|     | 8.4.1          | 概述                |      |
|     | 8.4.2          | TC1M模式寄存器         |      |
|     | 8.4.3          | TC1C计数寄存器         |      |
|     | 8.4.4          | TC1R自动装载寄存器       |      |
|     | 8.4.5          | TC1 时钟频率输出(蜂鸣器输出) |      |
|     | 8.4.6<br>8.4.7 | TC1 操作流程          |      |
|     | _              | PWM0 模式           |      |
|     |                | 概述                |      |
|     | 8.5.2          | TC0IRQ和PWM0 输出占空比 |      |
|     | 8.5.3          | PWM0 编程举例         |      |
|     | 8.5.4          | PWM0 占空比注意事项      |      |
|     |                | PWM1 模式           |      |
|     | 8.6.1          | 概述                |      |
|     | 8.6.2          | <br>TC1IRQ和PWM占空比 | . 92 |
|     | 8.6.3          | PWM1 编程举例         | . 92 |
|     | 8.6.4          | PWM1 占空比注意事项      | . 93 |
| 9   | 串行业            | 女发器SIO            | . 95 |
|     | 9.1            | 概述                | . 95 |
|     | 9.2            | SIOM模式寄存器         | . 97 |
|     | 9.3            | SIOB数据缓存器         | . 97 |
|     | 9.4            | SIOR寄存器           |      |
| 10  |                | ÎADC              |      |
|     | 10.1           | 概述                |      |
|     |                | ADDR安存器           |      |
|     |                | ADR寄存器            |      |
|     |                | ADB寄存器            |      |
|     |                | P4CON寄存器          |      |
|     | 10.6<br>10.7   | AD <b>转换时间</b>    |      |
|     | 10.7           | ADC电路             |      |
| 11  |                | ADC电时             |      |
| . 1 | 11.1           | 概述                |      |
|     |                | DAM寄存器            |      |
|     |                |                   |      |



|    | 11.3 D/A | 转换说明                         | 106 |
|----|----------|------------------------------|-----|
| 12 | 指令表      |                              | 107 |
| 13 | 电气特·     | 性                            | 108 |
|    | 13.1 极限  | · 是参数                        | 108 |
|    | 13.2 电气  | <b>(</b> 特性                  | 108 |
|    | 13.3 特性  | - H                          | 109 |
| 14 |          |                              |     |
|    | 14.1 开发  | 之                            | 110 |
|    | 14.1.1   | 在线仿真器(ICE)                   |     |
|    | 14.1.2   | 一次性编程烧录器(OTP烧录器)             |     |
|    | 14.1.3   | 集成开发环境( <b>IDE</b> )         |     |
|    | 14.2 SN8 | 3P2700A的指令限制                 |     |
|    | 14.2.1   | B0MOV M,I                    |     |
|    | 14.2.2   | B0XCH A, M                   | 111 |
|    | 14.3 RO  | M地址 8 处(中断向量)的有效指令           | 112 |
|    | 14.4 SN8 | 3P1708 升级为SN8P2708A          | 113 |
|    | 14.4.1   | 性能比较表                        | 113 |
|    | 14.4.2   | 配置编译选项                       | 114 |
|    | 14.5 SIO | 的移植                          | 115 |
|    | 14.5.1   | SN8P270XA SIO时序图             | 115 |
|    | 14.5.2   | SN8P170X SIO时序图              | 115 |
|    | 14.5.3   | SIOM配置表                      | 116 |
| 15 | OTP烧录作   | 這息                           | 117 |
|    | 15.1 烧录  | ·转接板信息                       | 117 |
|    | 15.1.1   | SN8P2700A系列的烧录引脚信息           | 119 |
| 16 | 封装       |                              | 120 |
|    |          | DIP28 PIN                    |     |
|    |          | P28 PIN                      |     |
|    |          | DP 28 PIN                    |     |
|    | -        | IP 32 PIN                    | _   |
|    |          | <sup>2</sup> 32 PINIP 40 PIN |     |
|    |          | P 44 PIN                     |     |
|    |          | DP 48 PIN                    |     |
|    |          | FP 48 PIN                    | _   |
| 17 |          | 正印命名规则                       |     |
|    |          | 2                            |     |
|    |          | - 加型号说明                      |     |
|    | , , ,    | 3举例                          |     |
|    |          | 时码规则                         |     |
|    |          |                              |     |



# **1** 产品简介

## 1.1 功能特性

◆ 存储器配置

OTP ROM 空间: 4K \* 16 位。 RAM 空间: 256 字节(bank 0 和 bank 1)。 8 层堆栈缓存器。

◆ I/O 引脚配置 (共 36 个)

输入输出双向端口: P0、P1、P2、P3、P4、P5。可编程的漏极开路引脚: P1.0、P1.1、P5.2。 具有唤醒功能的端口: P0、P1 的电平变化触发。 外部中断引脚: P0。 内置上拉电阻的端口: P0、P1、P2、P3、P4、P5。 P4 引脚和 ADC 输入引脚共用。

- ◆ 8 通道 12 位 ADC
- ◆ 1通道7位DAC
- ◆ 具有串行通信功能(SIO)
- ◆ 强大的指令系统

单周期指令系统(1T)。 绝大部分指令只需要一个周期。 查表指令 MOVC 可寻址整个 ROM 区。 JMP 和 CALL 指令可寻址整个 ROM 区。 具有硬件乘法器,支持乘法指令(MUL)。 ◆ 8个中断源

5 个内部中断: T0、TC0、TC1、SIO、ADC。 3 个外部中断: INT0、INT1、INT2。

◆ 3个8位定时/计数器

T0: 基本定时器。

TC0: 自动装载定时/计数器/PWM0/Buzzer 输出。 TC1: 自动装载定时/计数器/PWM1/Buzzer 输出。

内置看门狗定时器,时钟源由内部低速 RC 振荡电路提供 (16KHz @3V, 32KHz @5V)

◆ 双时钟系统

外部高速时钟: RC 模式高达 10 MHz。 外部高速时钟: 晶振模式高达 16MHz。

内部低速时钟: RC 模式, 16KHz(3V)、32KHz(5V)。

◆ 工作模式

普通模式: 高、低速时钟同时工作。 低速模式: 只有低速时钟在工作。 睡眠模式: 高、低速时钟同时停止工作。

绿色模式:由 TO 周期性的唤醒。

◆ 封装形式

SN8P2708A: SIP 48pins, SSOP 48 pins, LQFP 48 pins.

SN8P2707A: QFP 44 pins。 SN8P2706A: PDIP 40 pins。

SN8P2705A: PDIP 32 pins, SOP 32 pins.

SN8P2704A: SK-DIP28pins, SOP28pins, SSOP28pins

#### ☞ 特性选择列表

| 单片机型号     | ROM   | RAM   | 推糕 | 定时器 |     | 器 | 1/0 / | ADC | C DAC | PWM    | SIO | 唤醒功能的引脚数目     | 封装形式                 |  |
|-----------|-------|-------|----|-----|-----|---|-------|-----|-------|--------|-----|---------------|----------------------|--|
| 平月が1至 ラ   | KOW   | IVAIN | 产化 | T0  | TC0 |   |       | 700 | סאם   | Buzzer | OIO | 大胜为 配出 刀牌 数 日 | 34/04                |  |
| SN8P2708A | 4K*16 | 256   | 8  | ٧   | V   | ٧ | 36    | 8ch | 1ch   | 2      | 1   | 11            | DIP48/SSOP48/LQFP48  |  |
| SN8P2707A | 4K*16 | 256   | 8  | ٧   | V   | ٧ | 33    | 8ch | 1ch   | 2      | 1   | 9             | QFP44                |  |
| SN8P2706A | 4K*16 | 256   | 8  | ٧   | ٧   | ٧ | 30    | 8ch | 1ch   | 2      | 1   | 9             | DIP40                |  |
| SN8P2705A | 4K*16 | 256   | 8  | ٧   | V   | V | 23    | 8ch | 1ch   | 2      | 1   | 9             | DIP32/SOP32          |  |
| SN8P2704A | 4K*16 | 256   | 8  | ٧   | V   | V | 18    | 5ch | 1ch   | 2      | 1   | 8             | SKDIP28/SOP28/SSOP28 |  |



## ☞ SN8P1700 系列与 SN8P2700A 系列性能比较表

| 项目                                            | SN8P270xA                                                                      | SN8P170x                             |  |
|-----------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------|--|
| AC 抗干扰性                                       | 很好(在 VDD 和 VSS 之间添加一个47uf 的旁路电容)                                               | 一般                                   |  |
| 运算速度(16MHz 晶振)                                | 高达 16MIPS                                                                      | 4MIPS                                |  |
| 高速 PWM                                        | PWM 分辨率: 8/6/5/4 位<br>High Clock = 16MHz<br>8 位分辨率时高达 31.25K<br>4 位分辨率时高达 500K | PWM 分辨率: 只 8 位<br>在 16MHz 等于 7.8125K |  |
| 48PIN 封装时最大 I/O 引脚数<br>(SN8P2708A 与 SN8P1708) | 36                                                                             | 33                                   |  |
| 可编程漏极开路输出引脚                                   | P1.0 / P1.1 / P5.2 (SO)                                                        | -                                    |  |
| B0MOV M, I                                    | I 的值不能为 0E6 或 0E7                                                              | 无限制                                  |  |
| B0XCH A, M                                    | M 的地址不能为 80h~FFh                                                               | 无限制                                  |  |
| ROM 中地址 8 处的有效指令                              | JMP 或 NOP                                                                      | 无限制                                  |  |
| ADC 中断                                        | 有                                                                              | -                                    |  |
| ADC VREFL(参考低电压)                              | 有                                                                              | -                                    |  |
| ADC 时钟频率                                      | 七种设置(通过 ADCKS [2:0]设置)                                                         | 两种设置(通过 ADCKS 设置)                    |  |
| 绿色模式                                          | 有                                                                              | -                                    |  |
| 施密特触发输入引脚                                     | 所有的输入引脚(P4 口除外)                                                                | P0、RST、XIN                           |  |
| P0                                            | 输入/输出引脚                                                                        | 输入引脚                                 |  |
| P0.0 中断沿触发                                    | 下降沿/上升沿/双向沿                                                                    | 下降沿                                  |  |
| P0.1/P0.2 中断沿触发                               | 下降沿                                                                            | 下降沿                                  |  |
| P0 和 P1 的唤醒功能                                 | 电平变化触发(下降或上升)                                                                  | 低电平                                  |  |
| 唤醒时间                                          | 1/Fosc*4096 (sec) +振荡器稳定时间                                                     | 1/Fosc*2048 (sec) +振荡器稳定时间           |  |
| SIO 双缓存器                                      | 有                                                                              | -                                    |  |
| SIOM 寄存器的 SEDGE 位的定义                          | 参照 SIO 和使用                                                                     |                                      |  |
| TC0C/TC1C/TC0R/TC1R 的有效范围                     | 00H~ 0FFH                                                                      | 00H ~0FFH                            |  |
| 看门狗计数器时钟源                                     | 内部低速 RC 时钟                                                                     | 外部高速时钟                               |  |
| 看门狗清零                                         | MOV A, #5AH<br>B0MOV WDTR, A                                                   | B0BSET FWDRST                        |  |
| LVD                                           | 1.8V 常开                                                                        | 2.4V ON/OFF                          |  |
| 待机电流                                          | 1uA 5V                                                                         | 9uA 5V(LVD 美闭)                       |  |

#### \* 注:

本手册中提到的电平变化触发是指下降沿触发或上升沿触发;

为避免系统无法进入睡眠模式及降低待机电流,建议用户编程时使能 P1 口未定义引脚相应位的上拉电阻。

SN8P2704A:设置 P1UR的 bit5~bit7为"1"(P1.5~P1.7); SN8P2705A:设置 P1UR的 bit6~bit7为"1"(P1.6~P1.7); SN8P2706A:设置 P1UR的 bit6~bit7为"1"(P1.6~P1.7); SN8P2707A:设置 P1UR的 bit6~bit7为"1"(P1.6~P1.7)。



# 1.2 系统框图

系统框图





## 1.3 引脚配置

SN8P2704AK (SK-DIP28) SN8P2704AS (SOP28) SN8P2704AX (SSOP28)

|              |    |   |    | 1             |  |  |
|--------------|----|---|----|---------------|--|--|
| P1.4         | 1  | U | 28 | RST/VPP       |  |  |
| P1.3         | 2  |   | 27 | P0.2/INT2     |  |  |
| VDD          | 3  |   | 26 | P0.1/INT1     |  |  |
| P1.2         | 4  |   | 25 | P0.0/INT0     |  |  |
| P1.1         | 5  |   | 24 | VDD           |  |  |
| P1.0         | 6  |   | 23 | XIN           |  |  |
| VSS          | 7  |   | 22 | XOUT          |  |  |
| P4.4/AIN4    | 8  |   | 21 | VSS           |  |  |
| P4.3/AIN3    | 9  |   | 20 | P5.0/SCK      |  |  |
| P4.2/AIN2    | 10 |   | 19 | P5.1/SI       |  |  |
| P4.1/AIN1    | 11 |   | 18 | P5.2/SO       |  |  |
| P4.0/AIN0    | 12 |   | 17 | P5.3/BZ1/PWM1 |  |  |
| AVREFH       | 13 |   | 16 | P5.4/BZ0/PWM0 |  |  |
| VDD          | 14 |   | 15 | DAO           |  |  |
| SN8P2704AK/S |    |   |    |               |  |  |

SN8P2705AP (P-DIP32) SN8P2705AS (SOP32)

| 1            | U                                                                         | 32                                                                             | P5.0/SCK                                                                                                                    |  |  |  |
|--------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 2            |                                                                           | 31                                                                             | P5.1/SI                                                                                                                     |  |  |  |
| 3            |                                                                           | 30                                                                             | P5.2/SO                                                                                                                     |  |  |  |
| 4            |                                                                           | 29                                                                             | P5.3/BZ1/PWM1                                                                                                               |  |  |  |
| 5            |                                                                           | 28                                                                             | P5.4/BZ0/PWM0                                                                                                               |  |  |  |
| 6            |                                                                           | 27                                                                             | DAO                                                                                                                         |  |  |  |
| 7            |                                                                           | 26                                                                             | VDD                                                                                                                         |  |  |  |
| 8            |                                                                           | 25                                                                             | AVREFH                                                                                                                      |  |  |  |
| 9            |                                                                           | 24                                                                             | P4.0/AIN0                                                                                                                   |  |  |  |
| 10           |                                                                           | 23                                                                             | P4.1/AIN1                                                                                                                   |  |  |  |
| 11           |                                                                           | 22                                                                             | P4.2/AIN2                                                                                                                   |  |  |  |
| 12           |                                                                           | 21                                                                             | P4.3/AIN3                                                                                                                   |  |  |  |
| 13           |                                                                           | 20                                                                             | P4.4/AIN4                                                                                                                   |  |  |  |
| 14           |                                                                           | 19                                                                             | P4.5/AIN5                                                                                                                   |  |  |  |
| 15           |                                                                           | 18                                                                             | P4.6/AIN6                                                                                                                   |  |  |  |
| 16           |                                                                           | 17                                                                             | P4.7/AIN7                                                                                                                   |  |  |  |
| SN8P2705AP/S |                                                                           |                                                                                |                                                                                                                             |  |  |  |
|              | 3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16 | 2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16 | 2 31<br>3 30<br>4 29<br>5 28<br>6 27<br>7 26<br>8 25<br>9 24<br>10 23<br>11 22<br>12 21<br>13 20<br>14 19<br>15 18<br>16 17 |  |  |  |

**SN8P2705AQ (LQFP32)** 





#### **SN8P2706AP (P-DIP40)**

| _         | ir — |            |    |               |
|-----------|------|------------|----|---------------|
| P1.5      | 1    | U          | 40 | RST/VPP       |
| P1.4      | 2    |            | 39 | P0.2/INT2     |
| P1.3      | 3    |            | 38 | P0.1/INT1     |
| VDD       | 4    |            | 37 | P0.0/INT0     |
| P1.2      | 5    |            | 36 | VDD           |
| P1.1      | 6    |            | 35 | XIN           |
| P1.0      | 7    |            | 34 | XOUT          |
| P2.0      | 8    |            | 33 | VSS           |
| P2.1      | 9    |            | 32 | P2.4          |
| P2.2      | 10   |            | 31 | P5.0/SCK      |
| P2.3      | 11   |            | 30 | P5.1/SI       |
| VSS       | 12   |            | 29 | P5.2/SO       |
| P4.7/AIN7 | 13   |            | 28 | P5.3/BZ1/PWM1 |
| P4.6/AIN6 | 14   |            | 27 | P5.4/BZ0/PWM0 |
| P4.5/AIN5 | 15   |            | 26 | P5.5          |
| P4.4/AIN4 | 16   |            | 25 | P5.6          |
| P4.3/AIN3 | 17   |            | 24 | P5.7          |
| P4.2/AIN2 | 18   |            | 23 | DAO           |
| P4.1/AIN1 | 19   |            | 22 | VDD           |
| P4.0/AIN0 | 20   |            | 21 | AVREFH        |
|           |      | SN8P2706AP |    | •             |

#### **SN8P2707AQ (QFP44)**





#### **SN8P2708AX (SSOP48)**

| P2.5      | 1  | U          | 48 | P2.4          |
|-----------|----|------------|----|---------------|
| P2.6      | 2  |            |    | P5.0/SCK      |
| P2.7      |    |            |    | P5.1/SI       |
| P1.7      | 4  |            | 45 | P5.2/SO       |
| VSS       | 5  |            | 44 | P5.3/BZ1/PWM1 |
| Fcpu/XOUT | 6  |            | 43 | P3.0          |
| XIN       | 7  |            | 42 | P5.4/BZ0/PWM0 |
| VDD       | 8  |            | 41 | P5.5          |
| P0.0/INT0 | 9  |            | 40 | P5.6          |
| P0.1/INT1 | 10 |            | 39 | P5.7          |
| P0.2/INT2 | 11 |            | 38 | DAO           |
| RST/VPP   | 12 |            | 37 | VDD           |
| P1.5      | 13 |            | 36 | AVDD          |
| P1.4      | 14 |            | 35 | AVREFH        |
| P1.3      | 15 |            | 34 | P4.0/AIN0     |
| VDD       | 16 |            | 33 | P4.1/AIN1     |
| P1.6      | 17 |            | 32 | P4.2/AIN2     |
| P1.2      | 18 |            | 31 | P4.3/AIN3     |
| P1.1      | 19 |            | 30 | P4.4/AIN4     |
| P1.0      | 20 |            | 29 | P4.5/AIN5     |
| P2.0      | 21 |            | 28 | P4.6/AIN6     |
| P2.1      |    |            | 27 | P4.7/AIN7     |
| P2.2      |    |            | 26 | AVREFL        |
| P2.3      | 24 |            | 25 | VSS           |
|           |    | SN8P2708AX |    |               |

#### **SN8P2708AQ** (LQFP48)





# 1.4 引脚说明

| 引脚名称                     | 类型   | 功能说明                                                                             |
|--------------------------|------|----------------------------------------------------------------------------------|
| VDD, VSS                 | Р    | 电源输入端。                                                                           |
| AVDD                     | Р    | 模拟电路的电源输入端。                                                                      |
| RST/VPP                  | I, P | RST:系统复位输入引脚,施密特触发,低电平有效,通常保持高电平。<br>VPP:OTP 烧录引脚。                               |
| XIN                      | ı    | 振荡信号输入引脚。                                                                        |
| XOUT/Fcpu                | I/O  | 振荡信号输出引脚。<br>RC 模式时为 Fcpu 的输出引脚。                                                 |
| P0[1:0]/INT[1:0]         | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻,具有唤醒功能。<br>外部中断触发引脚(施密特触发)。<br>TC1/TC0事件计数器的信号输入引脚。 |
| P0.2/INT2                | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻,具有唤醒功能。<br>外部中断触发引脚(施密特触发)。                         |
| P1 [1:0]                 | I/O  | 双向输入/输出引脚,漏极开路引脚,输入模式时为施密特触发,内置上拉电阻。                                             |
| P1 [7:2]                 | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻。                                                    |
| P2 [7:0]                 | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻。                                                    |
| P3.0                     | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻。                                                    |
| P4.[7:0]/AIN[7:0]        | I/O  | 双向输入/输出引脚,非施密特触发,内置上拉电阻。<br>AIN[7:0]: ADC 的输入通道。                                 |
| P5.0/SCK                 | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻。<br>SCK: SIO 时钟引脚。                                  |
| P5.1/SO                  | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻。<br>SO: SIO 数据输出引脚。                                 |
| P5.2/SI                  | I/O  | 双向输入/输出引脚,漏极开路引脚,输入模式时为施密特触发,内置上拉电阻。<br>SI: SIO 数据输入引脚。                          |
| P5[4:3]/BZ[1:0]/PWM[1:0] | I/O  | 双向输入/输出引脚,输入模式时为施密特触发,内置上拉电阻。<br>Buzzer 输出引脚/PWM 输出引脚。                           |
| AVREFH                   | I    | ADC 参考电压的高电平输入引脚。                                                                |
| AVREFL                   | ı    | ADC 参考电压的低电平输入引脚。                                                                |
| DAO                      | 0    | DAC 信号输出引脚。                                                                      |



# 1.5 引脚电路结构图

Port 1.0, P1.1, P5.2 结构:



Port 0, 1, 2, 3, 5 结构:



Port 4 结构:





# **2** 中央处理器(CPU)

# 2.1 存储器

## 2.1.1 程序存储器 (ROM)

SN8P2700A 的程序存储器为 OTP ROM(一次性可编程),存储器容量为 4K\*16 位,可由 12 位程序计数器 PC 对程序存储器进行寻址,或由系统寄存器(R, X, Y 和 Z) 对 ROM 内的数据进行查表访问。

#### ☞ ROM: 4K



## 2.1.1.1 复位向量(0000H)

具有一个字长的系统复位向量(0000H)。

- 上电复位(NT0=1, NPD=0);
- 看门狗复位(NT0=0, NPD=0);
- 外部复位(NT0=1, NPD=1)。

发生上述任一种复位后,程序将从 0000H 处重新开始执行,系统寄存器也都将恢复为默认值。根据 PFLAG 寄存器中的 NT0 和 NPD 标志位的内容可以判断系统复位方式。下面一段程序演示了如何定义 ROM 中的复位向量。

#### ▶ 例:定义复位向量。

| , CXXIII | ORG<br>JMP | 0<br>START | ;<br>;跳至用户程序。        |
|----------|------------|------------|----------------------|
| START:   | ORG<br>    | 10H        | ;用户程序起始地址。<br>;用户程序。 |
|          | <br>ENDP   |            | ;程序结束。               |



## 2.1.1.2 中断向量(0008H)

中断向量地址为 0008H。一旦有中断响应,程序计数器 PC 的当前值就会存入堆栈缓存器并跳转到 0008H 开始执行中断服务程序。0008H 处的第一条指令必须是"JMP"或"NOP"。下面的示例程序说明了如何编写中断服务程序。

\* 注:"PUSH"、"POP"指令只保存 80H~87H 工作寄存器(包括 PFLAG),响应中断时用户必须通过程序来保存和恢复 ACC。 PUSH/POP 缓存器只有一层,且独立于 RAM 和堆栈区域。

▶ 注:0008H 处的第一条指令必须是"JMP"或者"NOP"。

▶ 例:定义中断向量,中断服务程序紧随 ORG 8 之后。

**ACCBUF** 

.DATA

ORG 0 ; 0000H.

DS 1

JMP START ; 跳转到用户程序。

..

ORG 8H ;中断向量。

NOP ; 0008H 处的第一条指令。

BOXCH A, ACCBUF ; 保存 ACC。

PUSH ; 保存 PFLAG 等工作寄存器。

•••

POP ; 恢复 PFLAG 等工作寄存器。

BOXCH A, ACCBUF ; 恢复 ACC。 RETI ; 中断返回。

...

START: ; 用户程序开始。

... ; 用户程序。

JMP START ;

•••

ENDP ;程序结束。



▶ 例:定义中断向量。中断服务程序在用户程序之后。

.DATA ACCBUF DS 1

.CODE

START:

ORG 0 ; 0000H.

JMP START ; 跳转到用户程序。

ORG 8H ;中断向量。

JMP MY\_IRQ ; 0008H, 跳转到中断服务程序。

ORG 10H

; 0010H,用户程序开始。

; 用户程序。

•••

JMP START

MY\_IRQ: ; 中断服务程序开始。

B0XCH A, ACCBUF ; 保存 ACC。

PUSH ; 保存 PFLAG 等工作寄存器。

...

**ENDP** 

POP ; 恢复 PFLAG 等工作寄存器。

;程序结束。

BOXCH A, ACCBUF ; 恢复 ACC。 RETI ; 中断返回。

\* 注:从上面的程序中容易得出 SONiX 的编程规则,有以下几点:

1、地址 0000H 的 "JMP"指令使程序从头开始执行;

2、地址 0008H 是中断向量,这里的第一条指令必须是 NOP 或 JMP;

3、用户的程序应该是一个循环。



## 2.1.1.3 查表

在 SONiX 单片机中,对 ROM 区中的数据进行查找,查表指针存放在寄存器 X,Y,Z中。寄存器 X 指向所找数据地 址的高字节(bit16~bit23),寄存器 Y 指向所找数据地址的中间字节(bit8~bit15),寄存器 Z 指向所找数据地址的低字 节(bit0~bit7)。执行完 MOVC 指令后,所查找数据低字节内容被存入 ACC 中,而数据高字节内容被存入 R 寄存器。

注:指令 B0MOV M, I 中的"I" (立即数) 不能是 E7H 或 E6H, 在查表的应用中, 用户必须检查 Y、Z 的值以确保其不为 E6H 或 E7H。设置 ROM 表的地址以避开 E6H 和 E7H。

例: 查找 ROM 地址为 "TABLE1"的值。

**B0MOV** X, #TABLE1\$H ;设置 table1 的高位字节地址。 **B0MOV** Y, #TABLE1\$M ;设置 table1 的中间字节地址。 **B0MOV** Z, #TABLE1\$L ;设置 table1 的低位字节地址。 MOVC ; 查表, R = 00H, ACC = 35H。

; 查找下一地址。

**INCMS** Ζ ; Z+1。 ; Z 没有溢出。 **JMP** @F **INCMS** Υ ; Z 溢出, Y=Y+1。 JMP @F ; Y 没有溢出。 **INCMS** Χ ; Y 溢出, X=X+1。

; 查表, R = 51H, ACC = 05H。

**ORG** 0100H ;设置 TABLE1 的开始地址为 0100H 以避开 "I" (立即数)为 E6H 和 E7H 的

TABLE1: DW 0035H ; 定义数据表数据(16-bit)。

> DW 5105H DW 2012H

NOP

MOVC ...

@@:

注: 当寄存器 Y/Z 溢出(从 FFH 变成 00H)时, X/Y 寄存器并不会自动加 1。用户必须注意这种情况以免查表错误。若 Z 溢出, Y 必须由程序加 1,同样,Y 溢出时,X 也要加 1。下面的宏指令 INC\_XYZ 可以对 X、Y 和 Z 寄存器自动处理。

▶ 例:宏指令INC\_XYZ。

INC\_XYZ **MACRO INCMS** Ζ ; Z+1。

JMP @F ;没有溢出。

**INCMS** Υ ; Y+1。 **JMP** @F ;没有溢出。

**INCMS** Х ; X+1。 NOP ;没有溢出。

@@:

**ENDM** 



▶ 例:通过宏指令 INC\_XYZ 对上例优化。

BOMOV X, #TABLE1\$H ; 设置 table1 的高位字节地址。 BOMOV Y, #TABLE1\$M ; 设置 table1 的中间字节地址。 BOMOV Z, #TABLE1\$L ; 设置 table1 的低位字节地址。 MOVC : 香表,R = 00H,ACC = 35H。

INC\_XYZ : 查找下一地址。

@@: MOVC ; 查表, R = 51H, ACC = 05H。

ORG 0100H ; 设置 TABLE1 的开始地址为 0100H 以避开 "I" (立即数)为 E6H 和

E7H 的情况。

TABLE1: DW 0035H ; 定义数据表数据(16-bit)。

DW 5105H DW 2012H

...

...

下面的程序通过累加器对X、Y和Z寄存器进行处理来实现查表功能,但需要特别注意进位时的处理。

▶ 例:通过指令 B0ADD/ADD 实现查表功能。

BOMOVX, #TABLE1\$H; 设置 table1 的高位字节地址。BOMOVY, #TABLE1\$M; 设置 table1 的中间字节地址。BOMOVZ, #TABLE1\$L; 设置 table1 的低位字节地址。

B0MOV A, BUF ;  $Z = Z + BUF_{\circ}$ 

BOADD Z, A

BOBTS1 FC ; 检查进位标志。

JMP GETDATA ; FC = 0. INCMS Y ; FC = 1, Y+1.

JMP GETDATA ; Y 没有溢出。 INCMS X ; Y 溢出,X=X+1。

NOP

GETDATA: ;

MOVC ; 存储数据, 如果 BUF = 0, 数据为 35H。

;如果BUF = 1,数据=5105H。 ;如果BUF = 2,数据=2012H

...

ORG 0100H ; 设置 TABLE1 的开始地址为 0100H 以避开 "I" (立即数)为 E6H 和 E7H

的情况。

TABLE1: DW 0035H ; 定义数据表数据(16-bit)。

DW 5105H DW 2012H

...



### 2.1.1.4 跳转表

跳转表能够实现多地址跳转功能。由于 PCL 和 ACC 的值相加即可得到新的 PCL,因此,可以通过对 PCL 加上不同 的 ACC 值来实现多地址跳转。ACC 值若为 n,PCL+ACC 即表示当前地址加 n,执行完当前指令后 PCL 值还会自加 1, 可参考以下范例。如果 PCL+ACC 后发生溢出, PCH 则自动加 1。由此得到的新的 PC 值再指向跳转指令列表中新的地 址。这样,用户就可以通过修改 ACC 的值轻松实现多地址的跳转。

注:PCH 只支持 PC 增量运算,而不支持 PC 减量运算。当 PCL+ACC 后如有进位,PCH 的值会自动加 1。PCL-ACC 后若有借 位,PCH 的值将保持不变,用户在设计应用时要加以注意。

#### 例:跳转表。

ORG 0100H ;跳转表从 ROM 前端开始。

**BOADD** PCL, A ; PCL = PCL + ACC, PCL 溢出时 PCH 加 1。 A0POINT

JMP ; ACC = 0, 跳至 A0POINT。 **JMP** A1POINT ; ACC = 1, 跳至 A1POINT。 **A2POINT JMP** ; ACC = 2, 跳至 A2POINT。 **JMP A3POINT** : ACC = 3, 跳至 A3POINT。

SONiX 单片机提供一个宏以保证可靠执行跳转表功能,它会自动检测 ROM 边界并将跳转表移至适当的位置。但采用 该宏程序会占用部分 ROM 空间。

#### 例:如果跳转表跨越 ROM 边界,将引起程序错误。

@JMP\_A **MACRO** VAL

> IF ((\$+1) !& 0XFF00) !!= ((\$+(VAL)) !& 0XFF00)

**JMP** (\$ | 0XFF) ORG (\$ | 0XFF) **ENDIF** 

B0ADD PCL, A

**ENDM** 

### 注: "VAL"为跳转表列表中列表个数。

#### 例:宏 "MACRO3.H"中, "@JMP\_A"的应用。

**B0MOV** A, BUF0 "BUF0"从0至 4。 @JMP\_A 5 ; 列表个数为 **5**。

**A0POINT** JMP ; ACC = 0, 跳至 A0POINT。 JMP A1POINT ; ACC = 1, 跳至 A1POINT。 **JMP** A2POINT ; ACC = 2, 跳至 A2POINT。 **A3POINT JMP** ; ACC = 3, 跳至 A3POINT。 **JMP** A4POINT

; ACC = 4, 跳至 A4POINT。



如果跳转表恰好位于 ROM BANK 边界处(00FFH~0100H),宏指令"@JMP\_A"将调整跳转表到适当的位置(0100H)。

; ACC = 4,跳至 A4POINT。

## ▶ 例: "@JMP\_A"运用举例。

JMP

;编译前 ROM 地址

|       | B0MOV  | A, BUF0 | ;"BUF0"从 0 到 4。       |
|-------|--------|---------|-----------------------|
|       | @JMP_A | 5       | ;列表个数为5。              |
| 00FDH | JMP    | A0POINT | ; ACC = 0,跳至 A0POINT。 |
| 00FEH | JMP    | A1POINT | ; ACC = 1,跳至 A1POINT。 |
| 00FFH | JMP    | A2POINT | ; ACC = 2,跳至 A2POINT。 |
| 0100H | JMP    | A3POINT | ; ACC = 3,跳至 A3POINT。 |
| 0101H | JMP    | A4POINT | ; ACC = 4,跳至 A4POINT。 |
|       |        |         |                       |

;编译后 ROM 地址

0104H

| B0MOV  | A, BUF0                     | ;"BUF0"从 0 到 4。                              |
|--------|-----------------------------|----------------------------------------------|
| @JMP_A | 5                           | ;列表个数为5。                                     |
| JMP    | A0POINT                     | ; ACC = 0,跳至 A0POINT。                        |
| JMP    | A1POINT                     | ; ACC = 1,跳至 A1POINT。                        |
| JMP    | A2POINT                     | ; ACC = 2,跳至 A2POINT。                        |
| JMP    | A3POINT                     | ; ACC = 3,跳至 A3POINT。                        |
|        | @JMP_A<br>JMP<br>JMP<br>JMP | @JMP_A 5 JMP A0POINT JMP A1POINT JMP A2POINT |

A4POINT

;用户程序结束地址低位地址存入 end\_addr1。

;用户程序结束地址中间地址存入 end\_addr2。



## 2.1.1.5 CHECKSUM计算

ROM 区末端位置的几个字限制使用,进行 Checksum 计算时,用户应避免对该单元的访问。

例:示例程序演示了如何对 00H 到用户程序结束进行 Checksum 计算。

A,#END\_USER\_CODE\$L MOV

**B0MOV** END\_ADDR1, A

A,#END\_USER\_CODE\$M MOV

**B0MOV** END\_ADDR2, A

CLR Υ ; 清 Y。 Ζ CLR ; 清 Z。

@@:

MOVC

ADD

**B0BCLR** FC

DATA1, A

MOV A, R

DATA2, A ADC

**JMP** END\_CHECK ; 检查 YZ 地址是否为代码的结束地址。

AAA:

**INCMS** Ζ

**JMP** @B ;若 Z!= 00H,进行下一个计算。

Y\_ADD\_1 **JMP** ; 若 Z = 00H, Y+1。

END\_CHECK:

MOV A, END\_ADDR1

**CMPRS** A, Z

; 检查 Z 地址是否为用户程序结束地址低位地址。 ; 否,则进行 Checksum 计算。

;程序结束。

;清标志位 C。

JMP AAAMOV A, END ADDR2

**CMPRS** A, Y

Υ

; 是则检查 Y 的地址是否为用户程序结束地址中间地址。 **JMP** AAA ; 否,则进行 Checksum 计算。

**JMP** CHECKSUM\_END ; 是则 Checksum 计算结束。

Y\_ADD\_1:

**INCMS** 

NOP

**JMP** 

@B ; 跳转到 Checksum 计算。

CHECKSUM\_END:

END\_USER\_CODE:



## 2.1.2 编译选项表(CODE OPTION)

| 编译选项         | 配置项目      | 功能说明                                       |
|--------------|-----------|--------------------------------------------|
|              | RC        | 外部高速时钟振荡器采用廉价的 RC 振荡电路, XOUT 是 Fcpu 的输出引脚。 |
| High_Clk     | 12M X'tal | 外部高速时钟振荡器采用高频晶体/陶瓷振荡器(如 12MHz~16MHz)。      |
|              | 4M X'tal  | 外部高速时钟振荡器采用标准晶体/陶瓷振荡器(如 4M~10MHz)。         |
|              | Always_On | 始终开启看门狗定时器,即使在睡眠模式和绿色模式下也处于开启状态。           |
| Watch_Dog    | Enable    | 开启看门狗定时器,但在睡眠模式下关闭;                        |
| Water_bog    | Lilable   | 看门狗定时器在绿色模式下处于开启状态。                        |
|              | Disable   | 关闭看门狗定时器。                                  |
|              | Fhosc/1   | 指令周期 = 1 个时钟周期,在 Fosc/1 的选项时必须关闭杂讯滤波功能。    |
|              | Fhosc/2   | 指令周期 = 2 个时钟周期,在 Fosc/2 的选项时必须关闭杂讯滤波功能。    |
|              | Fhosc/4   | 指令周期 = 4 个时钟周期。                            |
| Fcpu         | Fhosc/8   | 指令周期 = 8 个时钟周期。                            |
| Гори         | Fhosc/16  | 指令周期 = 16 个时钟周期。                           |
|              | Fhosc/32  | 指令周期 = 32 个时钟周期。                           |
|              | Fhosc/64  | 指令周期 = 64 个时钟周期。                           |
|              | Fhosc/128 | 指令周期 = 128 个时钟周期。                          |
| Security     | Enable    | ROM 代码加密。                                  |
| Security     | Disable   | ROM 代码不加密。                                 |
| Noise Filter | Enable    | 开启杂讯滤波功能。                                  |
| Noise_Filter | Disable   | 禁止杂讯滤波功能。                                  |

- ▶ 注:
- 1、在干扰严重的情况下,建议开启杂讯滤波功能,并将 Watch\_Dog 设置为"Always\_On";
- 2、编译选项 Fcpu 仅针对高速时钟,在低速模式下 Fcpu = Flosc/4;
- 3、在外部 RC 模式下,由编译器开启杂讯滤波功能;
- 4、在设置 Watch\_Dog 的编译选项为 "Enable"时,看门狗定时器在绿色模式下继续工作。



## 2.1.3 数据存储器(RAM)

SN8P2700A 单片机的片内 RAM 共有 384 个存储单元,地址范围为 000H~17FH。片内寄存器可分为通用数据存储 区和系统存储器两大部分。其中通用数据存储区共有 256 个存储单元,分为两个区域。通用数据存储区可存放用户自定义的变量,临时数据变量和中间数据变量,而系统寄存器则用来控制片内外设或表示外设的状态。

### ☞ RAM: 256 字节





#### 系统寄存器 2.1.4

## 2.1.4.1 系统寄存器列表

|   | 0     | 1     | 2     | 3     | 4     | 5     | 6     | 7     | 8     | 9     | Α     | В     | С     | D     | Е     | F     |
|---|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 8 | L     | Н     | R     | Z     | Υ     | Х     | PFLAG | RBANK | -     | -     | -     | -     | -     | -     | -     | -     |
| 9 | -     | -     | 1     | -     | -     | -     | -     | -     | -     | -     | 1     | -     | -     | 1     | -     | -     |
| Α | -     | -     | -     | -     | -     | -     | =     | -     | -     | -     | -     | -     | -     | -     | P4CON | -     |
| В | DAM   | ADM   | ADB   | ADR   | SIOM  | SIOR  | SIOB  | -     | -     | -     | -     | -     | -     | -     | -     | PEDGE |
| С | P1W   | P1M   | P2M   | P3M   | P4M   | P5M   | -     | -     | INTRQ | INTEN | OSCM  | -     | WDTR  | TC0R  | PCL   | PCH   |
| D | P0    | P1    | P2    | P3    | P4    | P5    | -     | -     | TOM   | T0C   | TC0M  | TC0C  | TC1M  | TC1C  | TC1R  | STKP  |
| Ε | P0UR  | P1UR  | P2UR  | P3UR  | P4UR  | P5UR  | @HL   | @YZ   | -     | -     | -     | -     | -     | -     | -     | -     |
| F | STK7L | STK7H | STK6L | STK6H | STK5L | STK5H | STK4L | STK4H | STK3L | STK3H | STK2L | STK2H | STK1L | STK1H | STK0L | STK0H |

## 2.1.4.2 系统寄存器说明

P4CON = P4 配置控制寄存器

= 专用寄存器,@HL间接寻址寄存器 L, H R = 工作寄存器和 ROM 查表数据缓存器

Χ = 专用寄存器, ROM 寻址寄存器 Y, Z = 专用寄存器,@YZ间接寻址寄存器,ROM 寻址寄存器

PFLAG = ROM 页及特殊标志寄存器 RBANK = RAM bank 选择寄存器 DAM = DAC 模式寄存器 ADM = ADC 模式寄存器

ADB = ADC 数据缓存器 ADR = ADC 精度选择寄存器 SIOM = SIO 模式控制寄存器 SIOR = SIO 时钟重装缓存器 SIOB P1W

= SIO 数据缓存器 = P1 口的唤醒功能寄存器 PnM = Pn 输入/输出模式控制寄存器 Pn = Pn 数据缓存器

INTRQ = 中断请求寄存器 INTEN = 中断使能寄存器 OSCM = 振荡模式控制寄存器 PCH, PCL = 程序计数器 TOM = T0 模式寄存器 TC0M = TC0 模式寄存器 = T0 计数寄存器 T0C TC0C = TC0 计数寄存器

TC1M = TC1 模式寄存器 TC0R = TC0 自动装载数据缓存器 TC1C = TC1 计数寄存器 TC1R = TC1 自动装载数据缓存器

STKP STK0~STK7 = 堆栈缓存器 = 堆栈指针缓存器 @HL = 间接寻址寄存器 @YZ = 间接寻址寄存器



## 2.1.4.3 系统寄存器的位定义

| 地址           | Bit7          | Bit6            | Bit5            | Bit4            | Bit3            | Bit2            | Bit1            | Bit0           | R/W        | 备注             |
|--------------|---------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------------|------------|----------------|
| 080H         | LBIT7         | LBIT6           | LBIT5           | LBIT4           | LBIT3           | LBIT2           | LBIT1           | LBIT0          | R/W        | L              |
| 081H         | HBIT7         | HBIT6           | HBIT5           | HBIT4           | HBIT3           | HBIT2           | HBIT1           | HBIT0          | R/W        | Н              |
| 082H         | RBIT7         | RBIT6           | RBIT5           | RBIT4           | RBIT3           | RBIT2           | RBIT1           | RBIT0          | R/W        | R              |
| 083H         | ZBIT7         | ZBIT6           | ZBIT5           | ZBIT4           | ZBIT3           | ZBIT2           | ZBIT1           | ZBIT0          | R/W        | Z              |
| 084H         | YBIT7         | YBIT6           | YBIT5           | YBIT4           | YBIT3           | YBIT2           | YBIT1           | YBIT0          | R/W        | Y              |
| 085H         | XBIT7<br>NT0  | XBIT6<br>NPD    | XBIT5           | XBIT4           | XBIT3           | XBIT2<br>C      | XBIT1<br>DC     | XBIT0<br>Z     | R/W<br>R/W | X<br>PFLAG     |
| 086H<br>087H | -             | - NPD           | -               | -               | -               | -               | -<br>-          | RBNKS0         | R/W        | RBANK          |
| 0AEH         | P4CON7        | P4CON6          | P4CON 5         | P4CON4          | P4CON3          | P4CON2          | P4CON1          | P4CON0         | W          | P4CON          |
| 0B0H         | DAENB         | DAB6            | DAB5            | DAB4            | DAB3            | DAB2            | DAB1            | DAB0           | R/W        | DAM 数据寄存器      |
| 0B011        | ADENB         | ADS             | EOC             | GCHS            | -               | CHS2            | CHS1            | CHS0           | R/W        | ADM 模式寄存器      |
| 0B2H         | ADB11         | ADB10           | ADB9            | ADB8            | ADB7            | ADB6            | ADB5            | ADB4           | R          | ADB 数据缓存器      |
| 0B3H         | ADCKS2        | ADCKS1          | ADLEN           | ADCKS0          | ADB3            | ADB2            | ADB1            | ADB0           | R/W        | ADR 寄存器        |
| 0B4H         | SENB          | START           | SRATE1          | SRATE0          | 0               | SCKMD           | SEDGE           | TXRX           | R/W        | SIOM 模式寄存器     |
| 0B5H         | SIOR7         | SIOR6           | SIOR5           | SIOR4           | SIOR3           | SIOR2           | SIOR1           | SIOR0          | W          | SIOR 重装缓存器     |
| 0B6H         | SIOB7         | SIOB6           | SIOB5           | SIOB4           | SIOB3           | SIOB2           | SIOB1           | SIOB0          | R/W        | SIOB 数据缓存器     |
| 0B8H         |               |                 |                 |                 |                 | P02M            | P01M            | P00M           | R/W        | P0M            |
| 0BFH         | -             | -               | -               | P00G1           | P00G0           | -               | -               | -              | R/W        | PEDGE          |
| 0C0H         | P17W          | P16W            | P15W            | P14W            | P13W            | P12W            | P11W            | P10W           | W          | P1W 唤醒功能寄存器    |
| 0C1H         | P17M          | P16M            | P15M            | P14M            | P13M            | P12M            | P11M            | P10M           | R/W        | P1M I/O 模式     |
| 0C2H         | P27M          | P26M            | P25M            | P24M            | P23M            | P22M            | P21M            | P20M           | R/W        | P2M I/O 模式     |
| 0C3H         | -             | -               | -               | -               | -               | -               | -               | P30M           | R/W        | P3M I/O 模式     |
| 0C4H         | P47M          | P46M            | P45M            | P44M            | P43M            | P42M            | P41M            | P40M           | R/W        | P4M I/O 模式     |
| 0C5H         | P57M          | P56M            | P55M            | P54M            | P53M            | P52M            | P51M            | P50M           | R/W        | P5M I/O 模式     |
| 0C8H         | ADCIRQ        | TC1IRQ          | TC0IRQ          | TOIRQ           | SIOIRQ          | P02IRQ          | P01IRQ          | P00IRQ         | R/W        | INTRQ          |
| 0C9H<br>0CAH | ADCIEN        | TC1IEN          | TC0IEN          | T0IEN<br>CPUM1  | SIOIEN<br>CPUM0 | P02IEN<br>CLKMD | P01IEN<br>STPHX | P00IEN         | R/W<br>R/W | INTEN<br>OSCM  |
| 0CCH         | WDTR7         | WDTR6           | WDTR5           | WDTR4           | WDTR3           | WDTR2           | WDTR1           | WDTR0          | W          | WDTR           |
| 0CDH         | TC0R7         | TC0R6           | TC0R5           | TC0R4           | TC0R3           | TC0R2           | TC0R1           | TC0R0          | W          | TC0R           |
| 0CEH         | PC7           | PC6             | PC5             | PC4             | PC3             | PC2             | PC1             | PC0            | R/W        | PCL            |
| 0CFH         | -             | -               | -               | -               | PC11            | PC10            | PC9             | PC8            | R/W        | PCH            |
| 0D0H         | -             | -               | -               | -               | -               | P02             | P01             | P00            | R/W        | P0 数据缓存器       |
| 0D1H         | -             | -               | P15             | P14             | P13             | P12             | P11             | P10            | R/W        | P1 数据缓存器       |
| 0D2H         | P27           | P26             | P25             | P24             | P23             | P22             | P21             | P20            | R/W        | P2 数据缓存器       |
| 0D3H         | -<br>D47      | -<br>D40        | -<br>D45        | -<br>D44        | -<br>D40        | -<br>D40        | -<br>D44        | P30            | R/W        | P3 数据缓存器       |
| 0D4H         | P47           | P46             | P45             | P44             | P43             | P42             | P41             | P40            | R/W        | P4 数据缓存器       |
| 0D5H         | P57           | P56             | P55             | P54             | P53             | P52             | P51             | P50            | R/W        | P5 数据缓存器       |
| 0D8H<br>0D9H | T0ENB<br>T0C7 | T0rate2<br>T0C6 | T0rate1<br>T0C5 | T0rate0<br>T0C4 | T0C3            | T0C2            | T0C1            | T0C0           | R/W<br>R/W | TOM<br>TOC     |
| 0DAH         | TC0ENB        | TC0rate2        | TC0rate1        | TC0rate0        | TC0CKS          | ALOAD0          | TC0OUT          |                |            | TCOM           |
| 0DBH         | TC0C7         | TC0C6           | TC0C5           | TC0C4           | TC0C3           | TC0C2           | TC0C1           | TC0C0          | R/W        | TC0C           |
| 0DCH         | TC1ENB        | TC1rate2        | TC1rate1        | TC1rate0        | TC1CKS          | ALOAD1          | TC10UT          | PWM1OUT        | R/W        | TC1M           |
| 0DDH         | TC1C7         | TC1C6           | TC1C5           | TC1C4           | TC1C3           | TC1C2           | TC1C1           | TC1C0          | R/W        | TC1C           |
| 0DEH         | TC1R7         | TC1R6           | TC1R5           | TC1R4           | TC1R3           | TC1R2           | TC1R1           | TC1R0          | W          | TC1R           |
| 0DFH         | GIE           | -               | -               | -               | STKPB3          | STKPB2          | STKPB1          | STKPB0         | R/W        | STKP 堆栈指针      |
| 0E0H<br>0E1H | -<br>P17R     | -<br>P16R       | -<br>P15R       | -<br>P14R       | -<br>P13R       | P02R<br>P12R    | P01R<br>P11R    | P00R<br>P10R   | W          | P0UR<br>P1UR   |
| 0E1H         | P27R          | P26R            | P25R            | P24R            | P23R            | P22R            | P21R            | P20R           | W          | P2UR           |
| 0E3H         | -             | -               | -               | -               | -               | -               | -               | P30R           | W          | P3UR           |
| 0E4H         | P47R          | P46R            | P45R            | P44R            | P43R            | P42R            | P41R            | P40R           | W          | P4UR           |
| 0E5H         | P57R          | P56R            | P54R            | P54R            | P53R            | P52R            | P51R            | P50R           | W          | P5UR           |
| 0E6H         | @HL7          | @HL6            | @HL5            | @HL4            | @HL3            | @HL2            | @HL1            | @HL0           | R/W        | @HL 间接寻址寄存器    |
| 0E7H         | @YZ7          | @YZ6            | @YZ5            | @YZ4            | @YZ3            | @YZ2            | @YZ1            | @YZ0           | R/W        | @YZ间接寻址寄存器     |
| 0E9H         | -             | -               | -               | -               | -               | P52OC           | P110C           | P10OC          | W          | P1OC           |
| 0F0H         | S7PC7         | S7PC6           | S7PC5           | S7PC4           | S7PC3           | S7PC2           | S7PC1           | S7PC0          | R/W<br>R/W | STK7L          |
| 0F1H<br>0F2H | S6PC7         | S6PC6           | S6PC5           | S6PC4           | S7PC11<br>S6PC3 | S7PC10<br>S6PC2 | S7PC9<br>S6PC1  | S7PC8<br>S6PC0 | R/W        | STK7H<br>STK6L |
| 0F3H         | -             | -               | -               | -               | S6PC11          | S6PC10          | S6PC9           | S6PC8          | R/W        | STK6H          |
| 0F4H         | S5PC7         | S5PC6           | S5PC5           | S5PC4           | S5PC3           | S5PC2           | S5PC1           | S5PC0          | R/W        | STK5L          |
| 0F5H         | -             | -               | -               | -               | S5PC11          | S5PC10          | S5PC9           | S5PC8          | R/W        | STK5H          |
| 0F6H         | S4PC7         | S4PC6           | S4PC5           | S4PC4           | S4PC3           | S4PC2           | S4PC1           | S4PC0          | R/W        | STK4L          |
| 0F7H         | -<br>C2DC7    | - C2DC6         | -<br>C2DCE      | -<br>C2DC4      | S4PC11          | S4PC10          | S4PC9           | S4PC8          | R/W        | STK4H          |
| 0F8H<br>0F9H | S3PC7         | S3PC6           | S3PC5           | S3PC4           | S3PC3<br>S3PC11 | S3PC2<br>S3PC10 | S3PC1<br>S3PC9  | S3PC0<br>S3PC8 | R/W<br>R/W | STK3L<br>STK3H |
| 0FAH         | S2PC7         | S2PC6           | S2PC5           | S2PC4           | S2PC3           | S2PC2           | S2PC1           | S2PC0          | R/W        | STK2L          |
| 0FBH         | -             |                 |                 |                 | S2PC11          | S2PC10          | S2PC9           | S2PC8          | R/W        | STK2H          |
|              |               |                 |                 |                 |                 |                 |                 |                |            |                |



| 地址   | Bit7  | Bit6  | Bit5  | Bit4  | Bit3   | Bit2   | Bit1  | Bit0  | R/W | 备注    |
|------|-------|-------|-------|-------|--------|--------|-------|-------|-----|-------|
| 0FCH | S1PC7 | S1PC6 | S1PC5 | S1PC4 | S1PC3  | S1PC2  | S1PC1 | S1PC0 | R/W | STK1L |
| 0FDH | -     | -     | -     | -     | S1PC11 | S1PC10 | S1PC9 | S1PC8 | R/W | STK1H |
| 0FEH | S0PC7 | S0PC6 | S0PC5 | S0PC4 | S0PC3  | S0PC2  | S0PC1 | S0PC0 | R/W | STK0L |
| 0FFH | -     | -     | -     | -     | S0PC11 | S0PC10 | S0PC9 | S0PC8 | R/W | STK0H |

- \* 注:
- 1、为了避免系统错误,在初始化时,请将上表所有寄存器的位都按照设计要求设置为确定的"1"或者"0";
- 2、所有寄存器名都已在 SN8ASM 编译器中做了宣告:
- 3、用户使用 SN8ASM 编译器对寄存器的位进行操作时,须在该寄存器的位前加 "F";
- 4、指令"b0bset","b0bclr","bset","bclr"只能用于可读写的寄存器("R/W")。

### 2.1.4.4 累加器

8 位数据寄存器 ACC 用来执行 ALU 与数据存储器之间数据的传送操作。如果操作结果为零(Z)或有进位产生(C 或 DC),程序状态寄存器 PFLAG 中相应位会发生变化。

ACC 并不在 RAM 中,因此在立即寻址模式中不能用"BOMOV"指令对其进行读写。

#### ▶ 例:读/写 ACC。

:将立即数写入ACC。

MOV A, #0FH

;把 ACC 中的数据存入 BUF 中。

MOV BUF, A BOMOV BUF, A

;把 BUF 中的数据送到 ACC 中。

MOV A, BUF BOMOV A, BUF

系统执行中断操作时, ACC 的数据不会自动存储, 用户需通过程序将中断入口处的 ACC 的数据送入存储器进行保存。可通过"PUSH"和"POP"指令对系统寄存器 80H~87H 的状态进行存储及恢复。

#### ▶ 例: ACC 和工作寄存器中断保护操作。

.DATA ACCBUF DS 1 ; 定义 ACCBUF 为 ACC 数据存储单元。

.CODE

INT\_SERVICE:

B0XCH A, ACCBUF ; ACC 数据送入缓存器。

PUSH ; PFLAG 等数据送入缓存器。

•••

POP

;恢复 PFLAG。

B0XCH A, ACCBUF ; 恢复 ACC。

RETI ; 退出中断。

\* 注:必须使用"B0XCH"指令进行 ACC 数据的中断恢复,否则 PFLAG 会被更改而导致出错。



## 2.1.4.5 程序状态寄存器PFLAG

寄存器PFLAG中包含ALU运算状态信息、系统复位状态信息和LVD低电压检测状态信息。其中,位NTO和NPD显示系统复位状态信息,包括上电复位、LVD复位、外部复位和看门狗复位;位C、DC和Z显示ALU的运算信息。

| 086H  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| PFLAG | NT0   | NPD   | -     | -     | -     | С     | DC    | Z     |
| 读/写   | R/W   | R/W   | -     | -     | 1     | R/W   | R/W   | R/W   |
| 复位后   | Х     | X     | -     | -     | -     | 0     | 0     | 0     |

Bit [7:6] NTO, NPD: 复位状态标志。

| NT0 | NPD | 复位状态   |
|-----|-----|--------|
| 0   | 0   | 看门狗复位  |
| 0   | 1   | 保留     |
| 1   | 0   | LVD 复位 |
| 1   | 1   | 外部复位   |

- Bit 2 **C:** 进位标志。
  - 1 =加法运算后有进位、减法运算没有借位发生或移位后移出逻辑"1"或比较运算的结果≥0;
  - 0=加法运算后没有进位、减法运算有借位发生或移位后移出逻辑"0"或比较运算的结果<0。
- **DC:** 辅助进位标志。
  - 1=加法运算时低四位有进位,或减法运算后没有向高四位借位;
  - 0=加法运算时低四位没有进位,或减法运算后有向高四位借位。
- Bit 0 **Z**: 零标志。
  - 1=算术/逻辑/分支转移运算的结果为零;
  - 0=算术/逻辑/分支转移运算的结果非零。
- \* 注:关于标志位 C、DC 和 Z 的更多信息请参阅指令集相关内容。



## 2.1.4.6 程序计数器

程序计数器 PC 是一个 12 位二进制程序地址寄存器,分高 4 位和低 8 位。专门用来存放下一条需要执行指令的内存地址。通常,程序计数器会随程序中指令的执行自动增加。

若程序执行 CALL 和 JMP 指令时, PC 指向特定的地址。

|     | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| PC  | -      | -      | -      | -      | PC11   | PC10   | PC9   | PC8   | PC7   | PC6   | PC5   | PC4   | PC3   | PC2   | PC1   | PC0   |
| 复位后 | -      | -      | -      | -      | 0      | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|     |        | PCH    |        |        |        |        |       |       |       |       |       | P(    | CL    |       |       |       |

#### ☞ 单地址跳转

在 SONiX 单片机里面,有 9 条指令(CMPRS、INCS、INCMS、DECS、DECMS、BTS0、BTS1、B0BTS0 和 B0BTS1)可完成单地址跳转功能。如果这些指令执行结果为真,那么 PC 值加 2 以跳过下一条指令。

; 否则执行 COSTEP。

如果位测试为真, PC 加 2。

B0BTS1 FC

; 若 Carry\_flag = 1 则跳过下一条指令。

JMP C0STEP

COSTEP: NOP

B0MOV A, BUF0 ; BUF0 送入 ACC。

BOBTSO FZ ; Zero flag = 0 则跳过下一条指令。

JMP C1STEP ; 否则执行 C1STEP。

C1STEP: NOP

如果 ACC 等于指定的立即数则 PC 值加 2, 跳过下一条指令。

CMPRS A, #12H

JMP COSTEP

COSTEP: NOP

执行加 1 指令后,结果为零时,PC 的值加 2,跳过下一条指令。

INCS:

INCS BUF0

JMP COSTEP ;如果 ACC 不为 "0" ,则跳至 COSTEP。

COSTEP: NOP

INCMS:

INCMS BUF0

JMP COSTEP ;如果 BUF0 不为"0",则跳至 COSTEP。

COSTEP: NOP

执行减1指令后,结果为零时,PC的值加2,跳过下一条指令。

DECS:

DECS BUF0

JMP COSTEP ;如果 ACC 不为"0",则跳至 COSTEP。

COSTEP: NOP

DECMS:

DECMS BUF0

JMP COSTEP ;如果 BUF0 不为"0",则跳至 COSTEP。

COSTEP: NOP



#### ☞ 多地址跳转

执行 JMP 或 ADD M,A(M=PCL)指令可实现多地址跳转。执行 ADD M, A、ADC M, A 或 B0ADD M, A 后,若 PCL 溢出,PCH 会自动进位。对于跳转表及其它应用,用户可以通过上述 3 条指令计算 PC 的值而不需要担心 PCL 溢出的问题。

\* 注:PCH 仅支持 PC 的递增运算而不支持递减运算。当 PCL+ACC 执行完 PCL 有进位时,PCH 会自动加 1,但执行 PCL-ACC 有借位发生,PCH 的值会保持不变。

▶ 例: PC = 0323H (PCH = 03H, PCL = 23H)。

; PC = 0323H

MOV A, #28H B0MOV PCL, A

PCL, A ; 跳到地址 0328H。

• • •

; PC = 0328H

MOV A, #00H

BOMOV PCL, A ; 跳到地址 0300H。

...

➢ 例: PC = 0323H (PCH = 03H, PCL = 23H)。

PC = 0323H

 B0ADD
 PCL, A
 ; PCL = PCL + ACC, PCH 的值不变。

 JMP
 A0POINT
 ; ACC = 0, 跳到 A0POINT。

 JMP
 A1POINT
 ; ACC = 1, 跳到 A1POINT。

 JMP
 A3POINT
 ; ACC = 3, 跳到 A3POINT。

..

...



## 2.1.4.7 H, L寄存器

寄存器 H 和 L 都是 8 位缓存器, 主要有以下两个功能:

- 通用工作寄存器;
- RAM 数据寻址指针@HL。

| 081H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| Н    | HBIT7 | HBIT6 | HBIT5 | HBIT4 | HBIT3 | HBIT2 | HBIT1 | HBIT0 |
| 读/写  | R/W   |
| 复位后  | X     | Х     | Х     | Х     | Х     | Х     | Х     | Х     |

| H080 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| L    | LBIT7 | LBIT6 | LBIT5 | LBIT4 | LBIT3 | LBIT2 | LBIT1 | LBIT0 |
| 读/写  | R/W   |
| 复位后  | Х     | X     | X     | Х     | X     | Х     | Х     | X     |

例:用 H、L 作为数据指针,访问 bank0 中 020H 处的内容。

**B0MOV** H, #00H **B0MOV** L, #20H **B0MOV** A, @HL

例:对 bank 0 中的数据进行清零处理。

CLR

; H = 0, 指向 bank 0。

**B0MOV** L, #7FH ; L = 7FH.

CLR\_HL\_BUF:

CLR @HL ;@HL 清零。

**DECMS** ; L-1, 如果 L=0, 程序结束。

JMP CLR\_HL\_BUF

@HL CLR

END\_CLR:



## 2.1.4.8 Y, Z寄存器

寄存器 Y 和 Z 都是 8 位缓存器, 主要用途如下:

- 普通工作寄存器;
- RAM 数据寻址指针@YZ;
- 配合指令 MOVC 对 ROM 数据进行查表。

| 084H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| Υ    | YBIT7 | YBIT6 | YBIT5 | YBIT4 | YBIT3 | YBIT2 | YBIT1 | YBIT0 |
| 读/写  | R/W   |
| 复位后  | X     | Х     | Х     | Х     | Х     | Х     | X     | Х     |

| 083H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| Z    | ZBIT7 | ZBIT6 | ZBIT5 | ZBIT4 | ZBIT3 | ZBIT2 | ZBIT1 | ZBIT0 |
| 读/写  | R/W   |
| 复位后  | X     | Х     | Х     | X     | Х     | Х     | X     | Х     |

例:用Y、Z作为数据指针,访问 bank0 中 025H 处的内容。

B0MOV Y, #00H ; Y 指向 RAM bank 0。 B0MOV Z, #25H ; Z 指向 25H。 B0MOV A, @YZ ; 数据送入 ACC。

▶ 例:利用数据指针@YZ 对 RAM 数据清零。

B0MOV Y, #0 ; Y = 0, 指向 bank 0。

BOMOV Z, #7FH ; Z = 7FH, RAM 区的最后单元。

CLR\_YZ\_BUF:

CLR @YZ ; @YZ清零。

DECMS Z ;

JMP CLR\_YZ\_BUF ; 不为零。

CLR @YZ

END\_CLR: ;

. . .

### 2.1.4.9 X寄存器

8 位缓存器 X 寄存器主要有以下两个功能:

- 通用工作寄存器;
- 查表时为 ROM 的数据指针。

| 085H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| X    | XBIT7 | XBIT6 | XBIT5 | XBIT4 | XBIT3 | XBIT2 | XBIT1 | XBIT0 |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

注:关于 X 寄存器的查表应用请参阅"查表"章节。

## 2.1.4.10 R寄存器

8 位缓存器 R 主要有以下两个功能:

- 作为工作寄存器使用;
- **存储执行查表指令后的高字节数据。**(执行 MOVC 指令,指定 ROM 单元的高字节数据会被存入 R 寄存器而低字节数据则存入 ACC。)

| 082H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| R    | RBIT7 | RBIT6 | RBIT5 | RBIT4 | RBIT3 | RBIT2 | RBIT1 | RBIT0 |
| 读/写  | R/W   |
| 复位后  | Х     | X     | Х     | Χ     | Х     | Х     | Χ     | X     |



# 2.2 寻址模式

## 2.2.1 立即寻址

将立即数直接送入 ACC 或指定的 RAM 单元。

▶ 例:立即数 12H 送入 ACC。

MOV A, #12H

▶ 例:立即数 12H 送入寄存器 R。

B0MOV R, #12H

注: 立即寻址模式中,指定的 RAM 单元必须是 80H~87H 的工作寄存器。

## 2.2.2 直接寻址

通过 ACC 对 RAM 单元数据进行操作。

▶ 例:地址 12H 处的内容送入 ACC。

B0MOV A, 12H

➢ 例: ACC 中数据写入 RAM 中 12H 单元。

B0MOV 12H, A

## 2.2.3 间接寻址

通过数据指针(H/L、Y/Z)对数据存储单元进行读写。

例:通过指针@HL间接寻址。

B0MOV H, #0 ; 清 "H" 以寻址 RAM bank 0。

BOMOV L, #12H ; 设定寄存器地址。

B0MOV A, @HL

》 例: 通过指针@YZ 间接寻址。

B0MOV Y, #0 ; 清 "Y" 以寻址 RAM bank 0。

BOMOV Z, #12H ; 设定寄存器地址。

BOMOV A, @YZ



# 2.3 堆栈

## 2.3.1 概述

SN8P2700A 的堆栈缓存器共有 8 层 程序进入中断或执行 CALL 指令时, 用来存储程序计数器 PC 的值。寄存器 STKP 为堆栈指针, 指向堆栈缓存器顶层, STKnH 和 STKnL 分别是各堆栈缓存器高、低字节。





## 2.3.2 堆栈寄存器

堆栈指针 STKP 是一个 3 位寄存器,存放被访问的堆栈单元地址,12 位数据存储器 STKnH 和 STKnL 用于暂存堆栈数据。以上寄存器都位于 bank 0。

堆栈操作遵循后进先出(LIFO)的原则,入栈时堆栈指针 STKP 的值减 1,出栈时 STKP 的值加 1,这样,STKP 总是指向堆栈缓存器项层单元。

系统进入中断或执行 CALL 指令之前,程序计数器 PC 的值被存入堆栈缓存器中进行入栈保护。

| 0DFH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|------|-------|-------|-------|-------|-------|--------|--------|--------|
| STKP | GIE   |       |       | -     | -     | STKPB2 | STKPB1 | STKPB0 |
| 读/写  | R/W   | -     | -     | -     | -     | R/W    | R/W    | R/W    |
| 复位后  | 0     | 1     | 1     | -     | -     | 1      | 1      | 1      |

Bit[2:0] **STKPBn**: 堆栈指针(n=0~2)。

Bit 7 GIE: 全局中断控制位。

0 = 禁止; 1 = 允许。

▶ 例:系统复位时,堆栈指针寄存器内容为默认值,但强烈建议在程序初始部分重新设定,如下面所示:

MOV A, #00000111B B0MOV STKP, A

| 0F0H~0FFH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|-----------|-------|-------|-------|-------|--------|--------|-------|-------|
| STKnH     | •     | -     | -     | -     | SnPC11 | SnPC10 | SnPC9 | SnPC8 |
| 读/写       | -     | -     | -     | -     | R/W    | R/W    | R/W   | R/W   |
| 复位后       | -     | -     | -     | -     | 0      | 0      | 0     | 0     |

| 0F0H~0FFH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| STKnL     | SnPC7 | SnPC6 | SnPC5 | SnPC4 | SnPC3 | SnPC2 | SnPC1 | SnPC0 |
| 读/写       | R/W   |
| 复位后       | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

STKn = STKnH, STKnL  $(n = 7 \sim 0)$  .



## 2.3.3 堆栈操作举例

执行程序调用指令 CALL 和响应中断服务时,堆栈指针 STKP 的值减 1,指针指向下一个堆栈缓存器。同时,对程序计数器 PC 的内容进行入栈保护。入栈操作如下表所示:

| 堆栈层数        |        | STKP   |        | 堆栈组   | 爰存器   | 注释        |
|-------------|--------|--------|--------|-------|-------|-----------|
| <b>堆似层数</b> | STKPB2 | STKPB1 | STKPB0 | 高字节   | 低字节   | <b>江仲</b> |
| 0           | 1      | 1      | 1      | Free  | Free  | =         |
| 1           | 1      | 1      | 0      | STK0H | STK0L | •         |
| 2           | 1      | 0      | 1      | STK1H | STK1L | =         |
| 3           | 1      | 0      | 0      | STK2H | STK2L | •         |
| 4           | 0      | 1      | 1      | STK3H | STK3L | -         |
| 5           | 0      | 1      | 0      | STK4H | STK4L | •         |
| 6           | 0      | 0      | 1      | STK5H | STK5L | •         |
| 7           | 0      | 0      | 0      | STK6H | STK6L | -         |
| 8           | 1      | 1      | 1      | STK7H | STK7L | =         |
| > 8         | 1      | 1      | 0      | -     | -     | 堆栈溢出      |

对应每个入栈操作,都有一个出栈操作来恢复程序计数器 PC 的值。RETI 指令用于中断服务程序中,RET 用于子程序调用。出栈时,STKP 加 1 并指向下一个空闲堆栈缓存器。堆栈恢复操作如下表所示:

|      | 7 7.147. | STKP   |        |       | 爰存器   |    |
|------|----------|--------|--------|-------|-------|----|
| 堆栈层数 | STKPB2   | STKPB1 | STKPB0 | 高字节   | 低字节   | 注释 |
| 8    | 1        | 1      | 1      | STK7H | STK7L | -  |
| 7    | 0        | 0      | 0      | STK6H | STK6L | -  |
| 6    | 0        | 0      | 1      | STK5H | STK5L | -  |
| 5    | 0        | 1      | 0      | STK4H | STK4L | -  |
| 4    | 0        | 1      | 1      | STK3H | STK3L | -  |
| 3    | 1        | 0      | 0      | STK2H | STK2L | -  |
| 2    | 1        | 0      | 1      | STK1H | STK1L | -  |
| 1    | 1        | 1      | 0      | STK0H | STK0L | -  |
| 0    | 1        | 1      | 1      | Free  | Free  | -  |



# 3 复位

## 3.1 概述

SN8P2700A 系列的单片机有以下几种复位方式:

- 上电复位;
- 看门狗复位;
- LVD 检测复位;
- 外部复位。

上述任一种复位发生时,所有的系统寄存器恢复默认状态,程序停止运行,同时程序计数器 PC 清零。复位结束后,系统从向量 0000H 处重新开始运行。PFLAG 寄存器的 NTO 和 NPD 两个标志位能够给出系统复位状态的信息。用户可以编程控制 NTO 和 NPD,从而控制系统的运行路径。

| 086H  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| PFLAG | NT0   | NPD   | -     | -     | -     | С     | DC    | Z     |
| 读/写   | R/W   | R/W   | -     | -     | -     | R/W   | R/W   | R/W   |
| 复位后   | Х     | Х     | -     | -     | -     | 0     | 0     | 0     |

Bit [7:6] NTO, NPD: 复位状态标志位

| NT0 | NPD | 复位情况       | 说明              |
|-----|-----|------------|-----------------|
| 0   | 0   | 看门狗复位      | 看门狗定时器溢出        |
| 0   | 1   | 系统保留       | -               |
| 1   | 0   | 上电及 LVD 复位 | 电源电压低于 LVD 检测电压 |
| 1   | 1   | 外部复位       | 外部复位引脚检测到低电平    |

任何一种复位方式都需要一定的响应时间,系统提供完善的复位流程以保证复位动作的顺利进行。对于不同类型的振荡器,完成复位所需要的时间也不同。因此,VDD的上升速度和不同晶振的起振时间都不固定。RC振荡器的起振时间最短,晶体振荡器的起振时间则较长。在用户使用的过程中,应考虑系统对上电复位时间的要求。





# 3.2 上电复位

上电复位与 LVD 操作密切相关。系统上电过程呈逐渐上升的曲线形式,需要一定时间才能达到正常电平值。下面给出上电复位的正常时序:

- 上电:系统检测到电源电压上升并等待其稳定;
- **外部复位:** 系统检测外部复位引脚状态。如果不为高电平,系统保持复位状态直到外部复位引脚的复位结束。
- 系统初始化: 所有的系统寄存器被置为默认状态;
- 振荡器开始工作:振荡器开始提供系统时钟;
- **执行程序:** 上电结束,程序开始运行。

## 3.3 看门狗复位

看门狗复位是系统的一种保护设置。在正常状态下,由程序将看门狗定时器清零。若出错,系统处于未知状态,看门 狗定时器溢出,此时系统复位。看门狗复位后,系统重启进入正常状态。看门狗复位的时序如下:

- **看门狗定时器状态:** 系统检测看门狗定时器是否溢出, 若溢出, 则系统复位;
- 系统初始化: 所有的系统寄存器被置为默认状态;
- **振荡器开始工作:** 振荡器开始提供系统时钟;
- **执行程序:** 上电结束,程序开始运行。

看门狗定时器应用注意事项如下:

- 对看门狗清零之前,检查 I/O 口的状态和 RAM 的内容可增强程序的可靠性;
- 不能在中断中对看门狗清零,否则无法侦测到主程序跑飞的状况;
- 程序中应该只在主程序中有一次清看门狗的动作,这种架构能够最大限度的发挥看门狗的保护功能。
- \* 注:关于看门狗定时器的详细内容,请参阅"看门狗定时器"有关章节。



# 3.4 掉电复位

#### 3.4.1 概述

掉电复位针对外部因素引起的系统电压跌落情形(例如:干扰或外部负载的变化),掉电复位可能会引起系统工作状态不正常或程序执行错误。



#### 掉电复位示意图

电压跌落可能会进入系统死区。系统死区意味着电源不能满足系统的最小工作电压要求。上图是一个典型的掉电复位示意图。图中,VDD 受到严重的干扰,电压值降的非常低。虚线以上区域系统正常工作,在虚线以下的区域内,系统进入未知的工作状态,这个区域称作死区。当 VDD 跌至 V1 时,系统仍处于正常状态;当 VDD 跌至 V2 和 V3 时,系统进入死区,则容易导致出错。以下情况系统可能进入死区:

#### DC 运用中:

DC 运用中一般都采用电池供电,当电池电压过低或单片机驱动负载时,系统电压可能跌落并进入死区。这时,电源不会进一步下降到 LVD 检测电压,因此系统维持在死区。

#### AC 运用中:

系统采用 AC 供电时,DC 电压值受 AC 电源中的噪声影响。当外部负载过高,如驱动马达时,负载动作产生的干扰也影响到 DC 电源。VDD 若由于受到干扰而跌落至最低工作电压以下时,则系统将有可能进入不稳定工作状态。

在 AC 运用中,系统上、下电时间都较长。其中,上电时序保护使得系统正常上电,但下电过程却和 DC 运用中情形类似,AC 电源关断后,VDD 电压在缓慢下降的过程中易进入死区。

## 3.4.2 系统工作电压

为了改善系统掉电复位的性能,首先必须明确系统具有的最低工作电压值。系统最低工作电压与系统执行速度有关,不同的执行速度下最低工作电压值也不同。



#### 系统工作电压与执行速度关系图

如上图所示,系统正常工作电压区域一般高于系统复位电压,同时复位电压由低电压检测(LVD)电平决定。当系统执行速度提高时,系统最低工作电压也相应提高,但由于系统复位电压是固定的,因此在系统最低工作电压与系统复位电压之间就会出现一个电压区域,系统不能正常工作,也不会复位,这个区域即为死区。



#### 掉电复位性能改进 3.4.3

如何改善系统掉电复位性能,有以下几点建议:

- LVD 复位:
- 看门狗复位:
- 降低系统工作速度;
- 采用外部复位电路(稳压二极管复位电路,电压偏移复位电路,外部 IC 复位)。
- 注: "稳压二极管复位电路"、"电压偏移复位电路"和"外部 IC 复位"能够完全避免掉电复位出错。

#### LVD 复位:



低电压检测(LVD)是 SONiX 8 位单片机内置的掉电复位保护装置,当 VDD 跌落并低于 LVD 检测电压值时,LVD 被触发,系统复位。不同的单片机有不同的 LVD 检测电平, LVD 检测电平值仅为一个电压点,并不能覆盖所有死区范围。 因此采用 LVD 依赖于系统要求和环境状况。电源变化较大时,LVD 能够起到保护作用,如果电源变化触发 LVD,系统工 作仍出错,那么 LVD 就不能起到保护作用,就需要采用其它复位方法。

#### 看门狗复位:

看门狗定时器用于保证系统正常工作。通常,会在主程序中将看门狗定时器清零,但不要在多个分支程序中清看门狗。 若程序正常运行,看门狗不会复位。当系统进入死区或程序运行出错的时候,看门狗定时器继续计数直至溢出,系统复位。 如果看门狗复位后电源仍处于死区,则系统复位失败,保持复位状态,直到系统工作状态恢复到正常值。

#### 降低系统工作速度:

系统工作速度越快最低工作电压值越高,从而加大工作死区的范围,因此降低系统工作速度不失为降低系统进入死区 几率的有效措施。所以,可选择合适的工作速度以避免系统进入死区,这个方法需要调整整个程序使其满足系统要求。

#### 附加外部复位电路:

外部复位也能够完全改善掉电复位性能。有三种外部复位方式可改善掉电复位性能: 稳压二极管复位电路, 电压偏移 复位电路和外部 IC 复位。它们都采用外部复位信号控制单片机可靠复位。



# 3.5 外部复位

外部复位功能由编译选项 "Reset\_Pin" 控制。将该编译选项置为 "Reset",可使能外部复位功能。外部复位引脚为施密特触发结构,低电平有效。复位引脚处于高电平时,系统正常运行。当复位引脚输入低电平信号时,系统复位。外部复位操作在上电和正常工作模式时有效。需要注意的是,在系统上电完成后,外部复位引脚必须输入高电平,否则系统将一直保持在复位状态。外部复位的时序如下:

- **外部复位(当且仅当外部复位引脚为使能状态)**:系统检测复位引脚的状态,如果复位引脚不为高电平,则系统会一直保持在复位状态,直到外部复位结束;
- **系统初始化:** 所有的系统寄存器被置为初始状态;
- **振荡器开始工作:** 振荡器开始提供系统时钟;
- **执行程序:** 上电结束,程序开始运行。

外部复位可以在上电过程中使系统复位。良好的外部复位电路可以保护系统以免进入未知的工作状态,如 AC 应用中的掉电复位等。



# 3.6 外部复位电路

## 3.6.1 基本RC复位电路



上图为一个由电阻 R1 和电容 C1 组成的基本 RC 复位电路,它在系统上电的过程中能够为复位引脚提供一个缓慢上升的复位信号。这个复位信号的上升速度低于 VDD 的上电速度,为系统提供合理的复位时序,当复位引脚检测到高电平时,系统复位结束,进入正常工作状态。

· 注:此 RC 复位电路不能解决非正常上电和掉电复位问题。

## 3.6.2 二极管及RC复位电路



上图中,R1 和C1 同样是为复位引脚提供输入信号。对于电源异常情况,二极管正向导通使C1 快速放电并与VDD保持一致,避免复位引脚持续高电平、系统无法正常复位。

☀ 注:"基本 RC 复位电路"和"二极管及 RC 复位电路"中的电阻 R2 都是必不可少的限流电阻,以避免复位引脚 ESD (Electrostatic Discharge)或 EOS(Electrical Over-stress)击穿。



## 3.6.3 稳压二极管复位电路



稳压二极管复位电路是一种简单的 LVD 电路,基本上可以完全解决掉电复位问题。如上图电路中,利用稳压管的击穿电压作为电路复位检测值,当 VDD 高于 "Vz + 0.7V"时,三极管集电极输出高电平,单片机正常工作;当 VDD 低于 "Vz + 0.7V"时,三极管集电极输出低电平,单片机复位。稳压管规格不同则电路复位检测值不同,根据电路的要求选择合适的二极管。

## 3.6.4 电压偏移复位电路



电压偏置复位电路是一种简单的 LVD 电路,基本上可以完全解决掉电复位问题。与稳压二极管复位电路相比,这种复位电路的检测电压值的精确度有所降低。电路中,R1 和 R2 构成分压电路,当 VDD 高于和等于分压值 "0.7V x (R1 + R2) / R1"时,三极管集电极 C 输出高电平,单片机正常工作; VDD 低于 "0.7V x (R1 + R2) / R1"时,集电极 C 输出低电平,单片机复位。

对于不同应用需求,选择适当的分压电阻。单片机复位引脚上电压的变化与 VDD 电压变化之间的差值为 0.7V。如果 VDD 跌落并低于复位引脚复位检测值,那么系统将被复位。如果希望提升电路复位电平,可将分压电阻设置为 R2>R1, 并选择 VDD 与集电极之间的结电压高于 0.7V。分压电阻 R1 和 R2 在电路中要耗电,此处的功耗必须计入整个系统的功耗中。

\* 注: 在电源不稳定或掉电复位的情况下。"稳压二极管复位电路"和"偏压复位电路"能够保护电路在电压跌落时避免系统出错。 当电压跌落至低于复位检测值时,系统将被复位。从而保证系统正常工作。



# 3.6.5 外部IC复位





# 4 系统时钟

## 4.1 概述

SN8P2700A 系列的单片机内带双时钟系统:高速时钟和低速时钟。高速时钟由外部振荡电路提供,低速时钟由内置的低速 RC 振荡电路(ILRC 16KHZ@3V、32KHz @5V)提供。两种时钟都可作为系统时钟源 Fosc,系统工作在低速模式时,Fosc 4 分频后作为一个指令周期(Fcpu)。

- 普通模式(高速时钟): Fcpu = Fhosc / N, N = 1~128, 由 Fcpu 编译选项控制;
- 低速模式(低速时钟): Fcpu = Flosc/4。

在干扰较严重的运行条件下,SONiX 提供的杂讯滤波器能够对外部干扰进行隔离以保护系统的正常工作。但在杂讯滤波器有效时,高速时钟的 Fcpu 被限制为 Fcpu=Fhosc/N, N=4~128。

## 4.2 系统时钟框图



- HOSC: High\_Clk 编译选项。
- Fhosc: 外部高速时钟频率。
- Flosc: 内部低速 RC 时钟频率(16KHz@3V,32KHz@5V)。
- Fosc: 系统时钟频率。Fcpu: 指令执行频率。



# 4.3 OSCM寄存器

寄存器 OSCM 控制振荡器的状态和系统的工作模式。

| 0CAH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| OSCM | 0     | 0     | 0     | CPUM1 | CPUM0 | CLKMD | STPHX | 0     |
| 读/写  | -     | -     | -     | R/W   | R/W   | R/W   | R/W   | -     |
| 复位后  | X     | X     | X     | 0     | 0     | 0     | 0     | Х     |

Bit 1 STPHX: 高速振荡器控制位。

0 = 高速时钟正常运行;

1 = 高速振荡器停止,内部低速 RC 振荡器运行。

Bit 2 CLKMD: 系统高/低速时钟模式控制位。

0 = 普通模式,系统采用高速时钟;

1 = 低速模式,系统采用内部低速时钟。

Bit[4:3] **CPUM[1:0]**: 单片机工作模式控制位。

00 = 普通模式;

01 = 睡眠模式;

10 = 绿色模式;

11 = 系统保留。

▶ 例:停止高速振荡器。

BOBSET FSTPHX

》 例:进入睡眠模式时,停止高速及低速振荡器。

B0BSET FCPUM0



# 4.4 系统高速时钟

系统高速时钟源来自外部高速振荡器,由编译选项"High\_Clk"控制。

| High_Clk | 功能说明                              |
|----------|-----------------------------------|
| RC       | 高速时钟为外部 RC 振荡器,Xout 是 Fcpu 的输出引脚。 |
| 12M      | 高速时钟为外部高速振荡器,频率范围为 10MHz ~ 16MHz。 |
| 4M       | 高速时钟为外部振荡器,频率范围为 2MHz ~ 10MHz。    |

## 4.4.1 外部高速时钟

外部高速时钟共三种模式:石英/陶瓷振荡器,RC及外部时钟源,由编译选项 High\_Clk 控制具体模式的选择。石英/陶瓷振荡器和 RC 振荡器的起振时间各不相同。RC 振荡器的起振时间相对较短。振荡器的起振时间决定了复位时间的长短。



## 4.4.1.1 石英/陶瓷振荡器

石英/陶瓷振荡器由 XIN、XOUT 口驱动,对于高速、普通和低速三种不同工作模式,振荡器的驱动电流也不同。编译选项"High\_Clk"支持不同的频率条件: 12MHz、4MHz等。



☀ 注: 上图中,XIN/XOUT/VSS 引脚与石英/陶瓷振荡器以及电容 C 之间的线路越短越好。



### 4.4.1.2 RC振荡器

通过编译选项"High\_Clk"的设置可控制 RC 振荡器的选择,RC 振荡器输出频率最高可达 10MHZ。改变电阻 R 可改变输出频率的大小,电容 C 的最佳容量为 50P~100P,如下图所示:



注: 电容 C 和电阻 R 应尽可能的接近单片机的 VDD。

### 4.4.1.3 外部时钟源

单片机可选择片外时钟信号作为系统时钟,从 XIN 脚送入。



注:外部振荡电路中的 GND 必须尽可能的接近单片机的 VSS 端口。



# 4.5 系统低速时钟

系统低速时钟源即内置的低速振荡器,采用 RC 振荡电路。低速时钟的输出频率受系统电压和环境温度的影响,通常为 5V 时输出 32KHZ, 3V 时输出 16KHZ。输出频率与工作电压之间的关系如下图所示。



低速时钟可作为看门狗定时器的时钟源。由 CLKMD 控制系统低速工作模式。

- Flosc = 内部低速 RC 振荡器(16KHz @3V, 32KHz @5V)。
- 低速模式 Fcpu = Flosc / 4。

在睡眠模式下可以停掉内部低速 RC。

例:在睡眠模式下,停止内部低速振荡器。 BOBSET FCPUMO

注:不可以单独停止内部低速时钟,由寄存器 OSCM 的位 CPUM0 和 CPUM1 的设置决定内部低速时钟的状态。

## 4.5.1 系统时钟测试

在设计过程中, 用户可通过软件指令周期对系统时钟速度进行测试。

▶ 例:外部振荡器的 Fcpu 指令周期测试。

BOBSET POM.0 ; PO.0 置为输出模式以输出 Fcpu 的触发信号。

@@:

B0BSET P0.0 B0BCLR P0.0 JMP @B

\* 注:不能直接从 XIN 引脚测试 RC 振荡频率,因为探针的连接会影响测试的准确性。



# 5 系统工作模式

# 5.1 概述

SN8P2700A 可在如下四种工作模式之间进行切换:

- 普通模式(高速模式);
- 低速模式;
- 省电模式(睡眠模式);
- 绿色模式。



系统模式切换示意图

#### 工作模式说明

| 工作模式           | 普通模式                  | 低速模式       | 绿色模式        | 睡眠模式     | 注释              |
|----------------|-----------------------|------------|-------------|----------|-----------------|
| EHOSC          | 运行                    | 由 STPHX 控制 | 由 STPHX 控制  | 停止       |                 |
| ILRC           | 运行    运行              |            | 运行          | 停止       |                 |
| CPU 指令         | 执行                    | 执行         | 停止          | 停止       |                 |
| T0 定时器         | *有效                   | *有效        | *有效         | 无效       | *T0ENB = 1 时有效  |
| TC0 定时器        | *有效                   | *有效        | *有效         | 无效       | *TC0ENB = 1 时有效 |
| TC1 定时器        | *有效                   | *有效        | *有效         |          | *TC1ENB = 1 时有效 |
| <b>丢</b> 门狗皇时哭 | 由 Watch_Dog<br>编译选项控制 |            |             |          | 请参阅编译选项章节       |
| 有门侧足的箱         | 编译选项控制                | 编译选项控制     | 编译选项控制      | 编译选项控制   | 用多购编件起频早日       |
| 内部中断           | 全部有效                  | 全部有效       | T0          | 全部无效     |                 |
| 外部中断           | 全部有效                  | 全部有效       | 全部有效        | 全部无效     |                 |
| 唤醒功能           | -                     | -          | P0,P1,T0,复位 | P0,P1,复位 |                 |

- EHOSC:外部高速时钟。
- ILRC: 内部低速时钟(RC 振荡器: 3V 时 16K, 5V 时 32K)。



# 5.2 系统模式切换

▶ 例:系统由普通/低速模式切换到睡眠模式。

BOBSET FCPUM0 ; CPUM0 = 1.

\* 注:系统进入睡眠模式后,只有具有唤醒功能的引脚和复位引脚能够将系统唤醒并回到普通模式中。

》 例: 系统由普通模式转换到低速模式。

BOBSET FCLKMD

BOBSET FSTPHX ; 外部高速振荡器停振。

例:低速模式转换到普通模式(外部高速振荡器始终处于工作状态)。

B0BCLR FCLKMD

》 例:系统由低速模式转换到普通模式(外部高速振荡器停止工作)。

在外部高速时钟停振的情况下,系统回到普通模式时至少需要延迟 20ms 以稳定振荡器。

BOBCLR FSTPHX : 启动外部振荡器。

B0MOV Z, #54 ; 若 VDD=5V. 内部 RC=32KHz 系统延迟 0.125msX162 = 20.25ms.

@@: DECMS Z JMP @B

BOBCLR FCLKMD : 系统回到普通模式。

》 例:系统由普通模式/低速模式进入绿色模式。

B0BSET FCPUM1

☀ 注:绿色模式下如果禁止 T0 的唤醒功能,则只有具有唤醒功能的引脚和复位引脚可以将系统唤醒(具有唤醒功能的引脚将系统返 回到上一个工作模式,复位引脚将系统返回到普通模式)。

▶ 例:系统由普通/低速模式进入绿色模式,并使能 T0 唤醒功能。

;设置 T0 定时器的唤醒功能。

B0BCLR FT0IEN ; 禁止 T0 中断。 B0BCLR FT0ENB ; 关闭 T0 定时器。 MOV A.#20H :

BOMOV A,#20日 , BOMOV TOM,A ; TO 时钟=Fcpu / 64。

MOV A.#64H

BOMOV TOC,A ; TOC 初始值= 64H (TO 中断间隔= 10 ms)。

BOBCLR FTOIEN ; 禁止 TO 中断。

BOBCLR FTOIRQ ; TO 中断请求寄存器清零。

BOBSET FTOENB ; 开启 TO。

; 进入绿色模式。

BOBCLR FCPUM0 BOBSET FCPUM1

☀ 注:绿色模式下如果使能 T0 的唤醒功能,则具有唤醒功能的引脚、复位引脚和 T0 都能够将系统唤醒。T0 的唤醒周期可编程控 制,请注意对 T0ENB 的设置。



# 5.3 系统唤醒

#### 5.3.1 概述

睡眠模式和绿色模式下,系统并不执行程序。唤醒触发信号可以将系统唤醒进入普通模式或低速模式。唤醒触发信号包括:外部触发信号(P0、P1的电平变换)和内部触发(T0定时器溢出)。

- 从睡眠模式唤醒后只能进入普通模式,且将其唤醒的触发只能是外部触发信号(P0、P1 电平变化);
- 如果是将系统由绿色模式唤醒返回到上一个工作模式(普通模式或低速模式),则可以是外部触发信号(P0、P1 电平变换)和内部触发信号(T0 溢出)。

#### 5.3.2 唤醒时间

系统进入睡眠模式后,高速时钟振荡器停止运行。把系统从睡眠模式唤醒时,单片机需要等待 4096 个外部高速时钟周期的时间,以等待振荡电路稳定工作,等待的这一段时间就称为唤醒时间。唤醒时间结束后,系统进入普通模式。

注:从绿色模式下唤醒系统不需要唤醒时间,因为系统时钟在绿色模式下仍然正常工作。

唤醒时间的计算如下:

唤醒时间 = 1/Fosc \* 4096 (sec) + 高速时钟启动时间

- 注:高速时钟的启动时间决定于 VDD 和振荡器的类型。
- ▶ 例:睡眠模式下,系统被唤醒进入普通模式。唤醒时间的计算如下:

唤醒时间 = 1/Fosc \* 4096 = 1.024 ms (Fosc = 4MHz)

总的唤醒时间 = 1.024ms + 振荡器启动时间

## 5.3.3 P1W唤醒功能控制寄存器

在绿色模式和睡眠模式下,有唤醒功能的 I/O 口能够将系统唤醒到普通模式。P0 和 P1 都具有唤醒功能,二者区别在于: P0 的唤醒功能始终有效,而 P1 的唤醒功能则由寄存器 P1W 控制。

| 0C0H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P1W  | P17W  | P16W  | P15W  | P14W  | P13W  | P12W  | P11W  | P10W  |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Bit[7:0] **P10W~P17W**: P1 唤醒功能控制位。

0 = 禁止; 1 = 使能。



# 6 中断

## 6.1 概述

SN8P2700A 提供 8 种中断源: 5 个内部中断(TO/TCO/TC1/SIO/ADC)和 3 个外部中断(INT0/INT1/INT2)。外部中断可以将系统从睡眠模式唤醒进入高速模式,在返回高速模式前,外部中断请求被锁定。一旦程序进入中断,寄存器STKP的位 GIE 将被硬件自动清零以避免再次响应其它中断。系统退出中断,即执行完 RETI 指令后,硬件自动将 GIE 置"1",以响应下一个中断。中断请求存放在寄存器 INTRQ 中。



¥ 注:程序响应中断时,位 GIE 必须处于有效状态。

# 中断使能寄存器INTEN

中断请求控制寄存器 INTEN 包括所有中断的使能控制位。INTEN 的有效位被置为"1",则系统进入该中断服务程 序,程序计数器入栈,程序转至 0008H 即中断程序。程序运行到指令 RETI 时,中断结束,系统退出中断服务。

| 0C9H  | Bit 7  | Bit 6  | Bit 5  | Bit 4 | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|-------|--------|--------|--------|-------|--------|--------|--------|--------|
| INTEN | ADCIEN | TC1IEN | TC0IEN | TOIEN | SIOIEN | P02IEN | P01IEN | P00IEN |
| 读/写   | R/W    | R/W    | R/W    | R/W   | R/W    | R/W    | R/W    | R/W    |
| 复位后   | 0      | 0      | 0      | 0     | 0      | 0      | 0      | 0      |

Bit 0 **P00IEN:** P0.0 外部中断 (INTO) 控制位。

0 = 禁止;

1 = 使能。

Bit 1 **P01IEN:** P0.1 外部中断(INT1)控制位。

1 = 使能。

Bit 2 **P02IEN:** P0.2 外部中断 (INT2) 控制位。

0 = 禁止;

1 = 使能。

SIOIEN: SIO 外部中断控制位。 Bit 3

0 = 禁止:

1 = 使能。

TOIEN: TO 中断控制位。 Bit 4

0 = 禁止;

1 = 使能。

TC0IEN: TC0 中断控制位。 Bit 5

0 = 禁止:

1 = 使能。

TC1IEN: TC1 中断控制位。 Bit 6

0 = 禁止:

1 = 使能。

ADCIEN: ADC 中断控制位。 Bit 7

0 = 禁止;

1 = 使能。



# 6.3 中断请求寄存器INTRQ

中断请求寄存器 INTRQ 中存放各中断请求标志。一旦有中断请求发生,INTRQ 中的相应位将被置"1",该请求被响应后,程序应将该标志位清零。根据 INTRQ 的状态,程序判断是否有中断发生,并执行相应的中断服务。

| 0C8H  | Bit 7  | Bit 6  | Bit 5  | Bit 4 | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|-------|--------|--------|--------|-------|--------|--------|--------|--------|
| INTRQ | ADCIRQ | TC1IRQ | TC0IRQ | T0IRQ | SIOIRQ | P02IRQ | P01IRQ | P00IRQ |
| 读/写   | R/W    | R/W    | R/W    | R/W   | R/W    | R/W    | R/W    | R/W    |
| 复位后   | 0      | 0      | 0      | 0     | 0      | 0      | 0      | 0      |

Bit 0 **P00IRQ:** P0.0 中断 (INT0) 请求标志位。

0 = INT0 无中断请求; 1 = INT0 有中断请求。

Bit 1 **P01IRQ:** P0.1 中断 (INT1) 请求标志位。

0 = INT1 无中断请求; 1 = INT1 有中断请求。

Bit 2 **P02IRQ:** P0.2 中断 (INT2) 请求标志位。

0 = INT2 无中断请求; 1 = INT2 有中断请求。

Bit 3 **SIOIRQ:** SIO 中断请求标志位。

0 = SIO 无中断请求; 1 = SIO 有中断请求。

Bit 4 **TOIRQ:** TO 中断请求标志位。

0 = T0 无中断请求; 1 = T0 有中断请求。

Bit 5 **TC0IRQ:** TC0 中断请求标志位。

0 = TC0 无中断请求; 1 = TC0 有中断请求。

Bit 6 **TC1IRQ:** TC1 中断请求标志位。

0 = TC1 无中断请求; 1 = TC1 有中断请求。

Bit 7 **ADCIRQ:** ADC 中断请求标志位。

0 = ADC 无中断请求; 1 = ADC 有中断请求。



# 6.4 GIE全局中断

只有当全局中断控制位 GIE 置"1"的时候程序才能响应中断请求。 一旦有中断发生,程序计数器 (PC) 指向中断向量地址 (0008H) ,堆栈层数加 1。

| 0DFH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|------|-------|-------|-------|-------|-------|--------|--------|--------|
| STKP | GIE   | ı     | -     | 1     | -     | STKPB2 | STKPB1 | STKPB0 |
| 读/写  | R/W   | -     | -     | -     | -     | R/W    | R/W    | R/W    |
| 复位后  | 0     | -     | -     | -     | -     | 1      | 1      | 1      |

Bit 7 GIE: 全局中断控制位。

**0** = 禁止全局中断; **1** = 使能全局中断。

▶ 例:设置全局中断控制位(GIE)。

BOBSET FGIE ; 使能 GIE。

★ 注:在所有中断中,GIE 都必须处于使能状态。

# 6.5 PUSH, POP处理

有中断请求发生并被响应后,程序转至 0008H 执行中断子程序。在响应中断之前,必须保存 ACC 和 PFLAG 的内容。系统提供 PUSH 和 POP 指令进行入栈保护和出栈恢复。但是这两条指令只保存工作寄存器 80H~87H(包括 PFLAG)的内容,因此 ACC 必须由程序来保存和恢复。

\* 注: PUSH、POP 指令只对工作寄存器 80H~87H 和 PFLAG 作中断保护,用户必须自行保存和恢复 ACC 的内容。PUSH/POP 缓存器只有一层,且独立于 RAM 和堆栈区域。

▶ 例:用 PUSH、POP 指令来保护和恢复 ACC 和 PFLAG。

.DATA ACCBUF DS 1

.CODE

ORG 0

JMP START

ORG 8H

JMP INT\_SERVICE

ORG 10H

START:

...

INT\_SERVICE:

BOXCH A, ACCBUF ; 保存 ACC。

PUSH ; 保存 PFLAG 等工作寄存器。

• • •

POP ; 恢复 PFLAG 等工作寄存器。

BOXCH A, ACCBUF ; 恢复 ACC。

RETI ; 退出中断。

ENDP



# 6.6 INTO (PO.0) 中断

INTO 被触发,则无论 POOIEN 处于何种状态,POOIRQ 都会被置"1"。如果 POOIRQ=1 且 POOIEN=1,系统响应该中断;如果 POOIRQ=1 而 POOIEN=0,系统并不会执行中断服务。在处理多中断时尤其需要注意。

#### 注: P0.0 的中断触发方式由 PEDGE 控制。

| 0BFH  | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| PEDGE | -     | -     | -     | P00G1 | P00G0 | -     | -     | -     |
| 读/写   | -     | -     | -     | R/W   | R/W   | -     | -     | -     |
| 复位后   | -     | -     | -     | 1     | 0     | -     | -     | -     |

Bit[4:3] **P00G[1:0]**: P0.0 中断触发控制位。

00 = 保留;

01 = 上升沿触发;

10 = 下降沿触发;

11 = 上升/下降沿触发(电平触发)。

》 例: INT0 中断请求设置,电平触发。

MOV A, #18H

BOMOV PEDGE, A ; INTO 置为电平触发。

B0BCLR FP00IRQ ; INT0 中断请求标志清零。

BOBSET FP00IEN ; 使能 INT0 中断。

BOBSET FGIE ; 使能 GIE。

➢ 例: INT0 中断。

ORG 8H

JMP INT\_SERVICE

INT\_SERVICE:

...; ACC 和 PFLAG 入栈保护。

B0BTS1 FP00IRQ ; 检测 P00IRQ。

JMP EXIT\_INT ; P00IRQ = 0,退出中断。

B0BCLR FP00IRQ ; P00IRQ 清零。

...; INT1 中断服务程序。

EXIT\_INT:

.. ; ACC 和 PFLAG 出栈恢复。



# 6.7 INT1 (P0.1) 中断

INT1 被触发,则无论 P01IEN 处于何种状态,P01IRQ 都会被置"1"。如果 P01IRQ=1 且 P01IEN=1,系统响应该中断;如果 P01IRQ=1 而 P01IEN=0,系统并不会执行中断服务。在处理多中断时尤其需要注意。

\*注: P0.1 中断由下降沿触发。

> 例: INT1 中断请求设置。

BOBCLR FP01IRQ ;清INT1中断请求标志。 BOBSET FP01IEN ;使能INT1中断。 BOBSET FGIE ;使能GIE。

➢ 例: INT1 中断。

ORG 8H

JMP INT\_SERVICE

INT\_SERVICE:

.. ; ACC 和 PFLAG 入栈保护。

 B0BTS1
 FP01IRQ
 ; 检查是否有 P01 中断请求标志。

 JMP
 EXIT\_INT
 ; P01IRQ = 0, 退出中断。

, roma = 0, zem ps

B0BCLR FP01IRQ ; 清 P01IRQ。

; INT1 中断服务程序。

EXIT\_INT:

… ; ACC 和 PFLAG 出栈恢复。



# 6.8 INT2 (P0.2) 中断

INT2 被触发,则无论 P02IEN 处于何种状态,P02IRQ 都会被置"1"。如果 P02IRQ=1 且 P02IEN=1,系统响应该中断;如果 P02IRQ=1 而 P02IEN=0,系统并不会执行中断服务。在处理多中断时尤其需要注意。

\* 注: P0.2 中断由下降沿触发。

▶ 例: INT2 中断请求设置。

BOBCLR FP02IRQ ;清 INT2 中断请求标志。

BOBSET FP02IEN ; 使能 INT2 中断。

BOBSET FGIE ; 使能 GIE。

▶ 例: INT1 中断服务程序。

ORG 8H
JMP INT\_SERVICE

INT\_SERVICE:

… ; ACC 和 PFLAG 入栈保护。

**B0BTS1 FP02IRQ** ; 检查是否有 P02 中断请求标志。

JMP EXIT\_INT ; P02IRQ = 0,退出中断。

B0BCLR FP02IRQ ; 清 P02IRQ。

...; INT2 中断服务程序。

EXIT\_INT:

···· ; ACC 和 PFLAG 出栈恢复。



# 6.9 T0 中断

TOC 溢出时,无论 TOIEN 处于何种状态,TOIRQ 都会置"1"。若 TOIEN 和 TOIRQ 都置"1",系统就会响应 TO的中断;若 TOIEN = 0,则无论 TOIRQ 是否置"1",系统都不会响应 TO 中断。尤其需要注意多种中断下的情形。

▶ 例:设置 T0 中断。

BOBCLR FTOIEN ;禁止T0中断。 BOBCLR FTOENB ; 禁止T0中断。

MOV A, #20H

 BOMOV
 TOM, A
 ; 设置 TO 时钟= Fcpu / 64。

 MOV
 A, #64H
 ; 初始化 TOC = 64H。

 BOMOV
 TOC, A
 ; 设置 TO 间隔时间= 10 ms。

BOBCLRFTOIRQ; TOIRQ 清零。BOBSETFTOIEN; 使能 TO 中断。BOBSETFTOENB; 开启定时器 TO。

BOBSET FGIE ; 使能 GIE。

▶ 例:T0 中断服务程序。

ORG 8H

JMP INT\_SERVICE

INT\_SERVICE:

… ; 保存 ACC 和 PFLAG。

BOBTS1 FTOIRQ ; 检查是否有 TO 中断请求标志。 JMP EXIT\_INT ; TOIRQ = 0,退出中断。

BOBCLR FTOIRQ ; 清 TOIRQ。

MOV A, #64H

B0MOV T0C, A

...

EXIT\_INT:

.. ; 恢复 ACC 和 PFLAG。



# 6.10 TC0 中断

TCOC 溢出时,无论 TCOIEN 处于何种状态,TCOIRQ 都会置"1"。若 TCOIEN 和 TCOIRQ 都置"1",系统就会 响应 TC0 的中断;若 TC0IEN = 0,则无论 TC0IRQ 是否置"1",系统都不会响应 TC0 中断。尤其需要注意多种中断下 的情形。

例: TC0 中断请求设置。

**FTC0IEN B0BCLR** ;禁止 TC0 中断。

**B0BCLR** FTC0ENB

MOV A, #20H

**B0MOV** TC0M, A ; TC0 时钟=Fcpu / 64。 MOV A, # 64H ; TC0C 初始值=64H。 **B0MOV** TC0C, A ; TC0 间隔= 10 ms。

**B0BCLR** FTC0IRQ ;清 TC0 中断请求标志。

**BOBSET FTC0IEN** ; 使能 TC0 中断。

**BOBSET** FTC0ENB

**BOBSET FGIE** ; 使能 GIE。

例: TC0 中断服务程序。

ORG 8H

**JMP** INT\_SERVICE

INT\_SERVICE:

;保存ACC和PFLAG。 ...

B0BTS1 **FTC0IRQ** ; 检查是否有 TC0 中断请求标志。

EXIT\_INT **JMP** ; TC0IRQ = 0, 退出中断。

FTC0IRQ **B0BCLR** ;清TC0IRQ。

MOV A, #64H

**B0MOV** TC0C, A ;清 TC0C。 ...

; TC0 中断程序。

EXIT\_INT:

;恢复ACC和PFLAG。 ...



# 6.11 TC1 中断

TC1C 溢出时,无论 TC1IEN 处于何种状态,TC1IRQ 都会置"1"。若 TC1IEN 和 TC1IRQ 都置"1",系统就会响应 TC1 的中断;若 TC1IEN = 0,则无论 TC1IRQ 是否置"1",系统都不会响应 TC1 中断。尤其需要注意多种中断下的情形。

▶ 例:设置 TC1 中断请求。

BOBCLR FTC1IEN ; 禁止 TC1 中断。 BOBCLR FTC1ENB ; 关闭 TC1 定时器。

MOV A, # 20H

 BOMOV
 TC1M, A
 ; 设置 TC1 时钟=Fcpu / 64。

 MOV
 A, # 64H
 ; 设置 TC1C 初始值=64H。

 BOMOV
 TC1C, A
 ; 设置 TC1 间隔时间=10 ms。

B0BCLRFTC1IRQ; 清 TC1 中断请求标志。B0BSETFTC1IEN; 使能 TC1 中断。B0BSETFTC1ENB; 开启 TC1 定时器。

BOBSET FGIE ; 使能 GIE。

▶ 例: TC1 中断服务程序。

ORG 8H ; JMP INT\_SERVICE

INT\_SERVICE:

… ; 保存 ACC 和 PFLAG。

BOBTS1 FTC1IRQ ; 检查是否有 TC1 中断请求标志。

JMP EXIT\_INT ; TC1IRQ = 0,退出中断。

B0BCLR FTC1IRQ ; 清 TC1IRQ。

MOV A, #64H B0MOV TC1C, A

B0MOV TC1C, A ; 清 TC1C。 ... ; TC1 中断服务程序。

· , TOT 中欧风发往行。

EXIT\_INT:

... ; 恢复 ACC 和 PFLAG。



# 6.12 SIO中断

当 SIO 完成数据传送后,无论 SIOIEN 处于何种状态,SIOIRQ 都会被置"1"。如果 SIOIRQ=1 且 SIOIEN=1,系统响应该中断;如果 SIOIRQ=1 而 SIOIEN=0,系统并不会执行中断服务。在处理多中断时尤其需要注意。

➢ 例: SIO 中断请求设置。

B0BCLR FSIOIRQ ; 清 SIO 中断请求标志。 B0BSET FSIOIEN ; 使能 SIO 中断。 B0BSET FGIE ; 使能 GIE。

➢ 例: SIO 中断服务程序。

ORG 8H ; JMP INT\_SERVICE

JMP INT\_SERVICE:

...; ACC 和 PFLAG 入栈保护。

BOBTS1 FSIOIRQ ; 检查是否有 SIO 中断请求标志。

JMP EXIT\_INT ; SIOIRQ = 0,退出中断。

B0BCLR FSIOIRQ ; 清 SIOIRQ。

; SIO 中断服务程序。

EXIT\_INT:

... ; ACC 和 PFLAG 出栈恢复

RETI ; 退出中断

# 6.13 ADC中断

当 ADC 转换完成后,无论 ADCIEN 是否使能,ADCIQR 都会置"1"。若 ADCIEN 和 ADCIQR 都置"1",那么系统就会响应 ADC 中断。若 ADCIEN = 0,不管 ADCIRQ 是否置"1",系统都不会进入 ADC 中断。用户应注意多种中断下的处理。

▶ 例: ADC 中断设置。

BOBCLR FADCIEN ; 禁止 ADC 中断。

MOV A, #10110000B ;

BOMOV ADM, A ; 允许 P4.0 ADC 输入, 使能 ADC 功能。

MOV A, #00000000B ; 设置 AD 转换速率 = Fcpu/16。

B0MOV ADR, A

BOBCLR FADCIRQ ; 清除 ADC 中断请求标志。

BOBSET FADCIEN ; 使能 ADC 中断。

BOBSET FGIE ; 使能 GIE。

BOBSET FADS ; 开始 AD 转换。

➢ 例: ADC 中断服务程序。

ORG 8H ;中断向量地址。

JMP INT\_SERVICE

INT\_SERVICE:

. 保存 ACC 和 PFLAG。

B0BTS1FADCIRQ; 检查是否有 ADC 中断。JMPEXIT\_INT; ADCIRQ = 0, 退出中断。

B0BCLR FADCIRQ ; 清 ADCIRQ。

; ADC 中断服务程序。

EXIT\_INT:

;恢复 ACC 和 PFLAG。



# 6.14 多中断操作举例

在同一时刻,系统中可能出现多个中断请求。此时,用户必须根据系统的要求对各中断进行优先权的设置。中断请求标志 IRQ 由中断事件触发,当 IRQ 处于有效值"1"时,系统并不一定会响应该中断。各中断触发事件如下表所示:

| 中断     | 有效触发       |
|--------|------------|
| P00IRQ | 由 PEDGE 控制 |
| P01IRQ | 由 PEDGE 控制 |
| P02IRQ | 由 PEDGE 控制 |
| T0IRQ  | TOC 溢出     |
| TC0IRQ | TC0C 溢出    |
| TC1IRQ | TC1C 溢出    |
| SIOIRQ | SIO 传送数据结束 |
| ADCIRQ | AD 转换结束    |

多个中断同时发生时,需要注意的是:首先,必须预先设定好各中断的优先权;其次,利用 IEN 和 IRQ 控制系统是否响应该中断。在程序中,必须对中断控制位和中断请求标志进行检测。

|              | 在程序中,必须对<br><b>条件下检测中断请</b> | 中断控制似和中断宿水/<br><b>求。</b> | <b>示态进行位测。</b>                          |
|--------------|-----------------------------|--------------------------|-----------------------------------------|
| 7 V3. D   A  | ORG<br>JMP                  | 8H<br>INT SERVICE        | ;                                       |
| INT_SERVICE: | OWN                         | IIVI_OLIVIOL             |                                         |
|              | •••                         |                          | ;保存ACC和PFLAG。                           |
| INTP00CHK:   | DODTO                       | FDOOLEN                  | ;检查是否有 INTO 中断请求。                       |
|              | B0BTS1<br>JMP               | FP00IEN<br>INTP01CHK     | ;检查是否使能 INTO 中断。                        |
|              | B0BTS0                      | FP00IRQ                  | ; 跳到下一个中断。<br>; 检查是否有 INTO 中断请求。        |
|              | JMP                         | INTP00                   | ;进入INTO中断。                              |
| INTP01CHK:   |                             |                          | ; 检查是否有 INT1 中断请求。                      |
|              | B0BTS1                      | FP01IEN                  | ; 检查是否使能 INT1 中断。                       |
|              | JMP                         | INTP02CHK                | ; 跳到下一个中断。                              |
|              | B0BTS0                      | FP01IRQ                  | ; 检查是否有 INT1 中断请求。                      |
| INTROOCHIZA  | JMP                         | INTP01                   | ;进入INT1中断。                              |
| INTP02CHK:   | B0BTS1                      | FP02IEN                  | ; 检查是否有 INT2 中断请求。<br>; 检查是否使能 INT2 中断。 |
|              | JMP                         | INTTOCHK                 | ;跳到下一个中断。                               |
|              | B0BTS0                      | FP02IRQ                  | ; 检查是否有 INT2 中断请求。                      |
|              | JMP                         | INTP02                   | ; 进入 INT2 中断。                           |
| INTT0CHK:    |                             |                          | ;检查是否有 T0 中断请求。                         |
|              | B0BTS1                      | FT0IEN                   | ; 检查是否使能 <b>T0</b> 中断。                  |
|              | JMP<br>B0BTS0               | INTTC0CHK<br>FT0IRQ      | ; 跳到下一个中断。                              |
|              | JMP                         | INTTO                    | ; 检查是否有 T0 中断请求。<br>; 进入 T0 中断。         |
| INTTC0CHK:   | OWN                         | 114110                   | ; 检查是否有 <b>TC0</b> 中断请求。                |
|              | B0BTS1                      | FTC0IEN                  | ; 检查是否使能 <b>TC0</b> 中断。                 |
|              | JMP                         | INTTC1CHK                | ; 跳到下一个中断。                              |
|              | B0BTS0                      | FTC0IRQ                  | ; 检查是否有 TC0 中断请求。                       |
| INITTOAOLUG  | JMP                         | INTTC0                   | ; 进入 TC0 中断。                            |
| INTTC1CHK:   | B0BTS1                      | FTC1IEN                  | ; 检查是否有 TC1 中断请求。<br>; 检查是否使能 TC1 中断。   |
|              | JMP                         | INTSIOCHK                | ;跳到下一个中断。                               |
|              | B0BTS0                      | FTC1IRQ                  | ; 检查是否有 <b>TC1</b> 中断请求。                |
|              | JMP                         | INTTC1                   | ; 进入 TC1 中断。                            |
| INTSIOCHK:   |                             |                          | ;检查是否有 SIO 中断请求。                        |
|              | B0BTS1                      | FSIOIEN                  | ; 检查是否使能 SIO 中断。                        |
|              | JMP<br>B0BTS0               | INTADCHK<br>FSIOIRQ      | ; 跳到下一个中断。<br>; 检查是否有 SIO 中断请求。         |
|              | JMP                         | INTSIO                   | ;进入SIO中断。                               |
| INTADCHK:    | OWN                         | 111010                   | ; 检查是否有 ADC 中断请求。                       |
|              | B0BTS1                      | FADCIEN                  | ; 检查是否使能 ADC 中断。                        |
|              | JMP                         | INT_EXIT                 | ,                                       |
|              | B0BTS0                      | FADCIRQ                  | ; 检查是否有 ADC 中断请求。                       |
| INT_EXIT:    | JMP                         | INTADC                   | ;进入ADC中断。                               |
| L/XII.       |                             |                          | ;恢复C和PFLAG。                             |
|              | RETI                        |                          | ;退出中断。                                  |



# **7** ио□

# 7.1 I/O口模式

寄存器 PnM 控制 I/O 口的工作模式。

| 0B8H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P0M  | -     | -     |       | -     | -     | P02M  | P01M  | P00M  |
| 读/写  | -     | -     | -     | -     | -     | R/W   | R/W   | R/W   |
| 复位后  | -     | -     | -     | -     | -     | 0     | 0     | 0     |

| 0C1H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P1M  | P17M  | P16M  | P15M  | P14M  | P13M  | P12M  | P11M  | P10M  |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| 0C2H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P2M  | P27M  | P26M  | P25M  | P24M  | P23M  | P22M  | P21M  | P20M  |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| 0C3H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P3M  | -     | -     | -     | -     | -     | -     | -     | P30M  |
| 读/写  | -     | -     | -     | -     | -     | -     | -     | R/W   |
| 复位后  | -     | -     | -     | -     | -     | -     | -     | 0     |

| 0C4H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P4M  | P47M  | P46M  | P45M  | P44M  | P43M  | P42M  | P41M  | P40M  |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| 0C5H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P5M  | P57M  | P56M  | P55M  | P54M  | P53M  | P52M  | P51M  | P50M  |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Bit[7:0] **PnM[7:0]:** Pn 模式控制位(n = 0~5)。

0 = 输入模式;

1 = 输出模式。

- \* 注:用户可通过位操作指令(B0BSET、B0BCLR)对 I/O 口进行编程控制;
- \* 注: 如果没有用到单片机的 ADC 功能模块,用户需将 AVDD 与 VDD 相连以避免 P4 口的 I/O 功能出错。

#### ▶ 例:I/O 模式选择。

CLR P0M CLR P4M CLR P5M

MOV A, #0FFH ; 设置为输出模式。

MOV A, #0FFH B0MOV P0M, A B0MOV P4M,A B0MOV P5M, A

B0BCLR P4M.0 ; P4.0 设为输入模式。

BOBSET P4M.0 ; P4.0 设为输出模式。

;设置为输入模式。



# 7.2 I/O口上拉电阻

| 0E0H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P0UR | -     | -     | -     | -     | -     | P02R  | P01R  | P00R  |
| 读/写  | -     | -     | -     | -     | -     | W     | W     | W     |
| 复位后  | -     | -     | -     | -     | -     | 0     | 0     | 0     |

| 0E1H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P1UR | P17R  | P16R  | P15R  | P14R  | P13R  | P12R  | P11R  | P10R  |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| 0E2H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P2UR | P27R  | P26R  | P25R  | P24R  | P23R  | P22R  | P21R  | P20R  |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| 0E3H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P3UR | -     | -     | -     | -     | -     | -     | -     | P30R  |
| 读/写  | -     | -     | -     | -     | -     | -     | -     | W     |
| 复位后  | -     | -     | -     | -     | -     | -     | -     | 0     |

| 0E4H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P4UR | P47R  | P46R  | P45R  | P44R  | P43R  | P42R  | P41R  | P40R  |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| 0E5H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P5UR | P57R  | P56R  | P55R  | P54R  | P53R  | P52R  | P51R  | P50R  |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### ▶ 例: I/O 口的上拉电阻。

MOV A, #0FFH ; 使能 P0、P4、P5 的上拉电阻。

BOMOV POUR, A BOMOV P4UR,A BOMOV P5UR, A



# 7.3 I/O口数据寄存器

| 0D0H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P0   | -     | -     | -     | -     | -     | P02   | P01   | P00   |
| 读/写  | -     | -     | -     | -     | -     | R/W   | R/W   | R/W   |
| 复位后  | -     | -     | -     | -     | -     | 0     | 0     | 0     |

| 0D1H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P1   | P17   | P16   | P15   | P14   | P13   | P12   | P11   | P10   |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| 0D2H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P2   | P27   | P26   | P25   | P24   | P23   | P22   | P21   | P20   |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| 0D3H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P3   | -     | ı     | ı     | ı     | ı     | ı     | ı     | P30   |
| 读/写  | -     | -     | -     | -     | -     | -     | -     | R/W   |
| 复位后  | -     | -     | -     | -     | -     | -     | -     | 0     |

| 0D4H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P4   | P47   | P46   | P45   | P44   | P43   | P42   | P41   | P40   |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| 0D5H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P5   | P57   | P56   | P55   | P54   | P53   | P52   | P51   | P50   |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

▶ 例:读取输入口的数据。

B0MOV A, P0 ; 读取 P0、P4 和 P5 口的数据。

B0MOV A, P4 B0MOV A, P5

▶ 例:写入数据到输出端口。

MOV A, #0FFH ; 写入数据 FFH 到 P0、P4 和 P5。

B0MOV P0, A B0MOV P4, A B0MOV P5, A

▶ 例:写入1位数据到输出端口。

B0BSET P4.0 ; P4.0 和 P5.3 置 1。

B0BSET P5.3

B0BCLR P4.0 ; P4.0 和 P5.3 清 0。

B0BCLR P5.3



# 7.4 I/O漏极开路寄存器

P1.0/P1.1/P5.2 内置漏极开路功能,当使能该功能时,P1.0/P1.1/P5.2 必须设置为输出模式。漏极开路的外部电路如下图所示:



上图中的上拉电阻必不可少,漏极开路的输出高电平由上拉电阻驱动,输出低电平。

| 0E9H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| P10C | -     | -     | -     | -     | -     | P52OC | P110C | P10OC |
| 读/写  | -     | -     | -     | -     | -     | W     | W     | W     |
| 复位后  | -     | -     | -     | -     | -     | 0     | 0     | 0     |

Bit 2 **P52OC:** P5.2 漏极开路控制位。

0 = 禁止漏极开路功能;

1 = 开启漏极开路功能。

Bit [1:0] P110C~P10OC: P1.1 和 P10 漏极开路控制位。

0 = 禁止漏极开路功能;

1 = 开启漏极开路功能。

▶ 例:开启 P1.0 的漏极开路功能并输出高电平。

B0BSET P1.0 ; P1.0 置高。

BOBSET P1M.0 ; P1.0 设为输出模式。

MOV A, #01H ; 开启 P1.0 的漏极开路功能。 BOMOV P1OC, A

- ¥ 注:P10OC 是只写寄存器,只能通过指令"MOV"设置 P10OC。
- 》 例: 禁止 P1.0 的漏极开路功能并输出低电平。

MOV A, #0 ; 禁止 P1.0 的漏极开路功能。 BOMOV P1OC, A

\* 注:禁止 P1.0 的漏极开路功能后,P1.0 恢复到之前的 I/O 模式。



## 7.5 P4 与ADC共用引脚

P4 口和 ADC 的输入口共用。同一时间只能设置 P4 口的一个引脚作为 ADC 的测量信号输入口(通过 ADM 寄存器来设置),其它引脚则作为普通 I/O 使用。具体应用中,当输入一个模拟信号到 CMOS 结构端口,尤其当模拟信号为 1/2 VDD时,将可能产生额外的漏电流。同样,当 P4 口外接多个模拟信号时,也会产生额外的漏电流。在睡眠模式下,上述漏电流会严重影响到系统的整体功耗。P4CON 为 P4 口的配置寄存器。将 P4CON[7:0]置"1",其对应的 P4 口将被设置为纯模拟信号输入口,从而避免上述漏电流的情况。

| 0AEH  | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|
| P4CON | P4CON7 | P4CON6 | P4CON5 | P4CON4 | P4CON3 | P4CON2 | P4CON1 | P4CON0 |
| 读/写   | R/W    |
| 复位后   | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Bit[7:0] **P4CON[7:0]:** P4.n 控制位。

0 = P4.n 作为模拟信号输入引脚(ADC 输入引脚)或普通 I/O 引脚;

1 = P4.n 只能作为模拟信号输入引脚,不能作为普通 I/O 引脚。

← 注:当 P4.n 作为普通 l/O 口而不是 ADC 输入引脚时,P4CON.n 必须置为 0,否则 P4.n 的普通 l/O 信号会被隔离开来。

P4 的 ADC 模拟输入由寄存器 ADM 的 GCHS 和 CHSn 位控制,若 GCHS = 0,P4.n 为普通的 I/O 引脚,若 GCHS = 1,CHSn 所对应的 P4.n 用作 ADC 模拟信号输入引脚。用户应该将 P4 ADC 输入引脚设置为无上拉电阻的输入模式。

| 0B1H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| ADM  | ADENB | ADS   | EOC   | GCHS  | -     | CHS2  | CHS1  | CHS0  |
| 读/写  | R/W   | R/W   | R/W   | R/W   | -     | R/W   | R/W   | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | -     | 0     | 0     | 0     |

Bit 4 GCHS: ADC 输入通道控制位。

0 = 禁止 AIN 通道;

1 = 开启 AIN 通道。

Bit[2:0] CHS[2:0]: ADC 输入通道选择位。

 $000 = AIN0; \quad 001 = AIN1; \quad ...; \quad 110 = AIN6; \quad 111 = AIN7.$ 

▶ 注:在设置 P4.n 为普通的 I/O 引脚时,必须保证 P4.n 的 ADC 功能已经被禁止。

▶ 例:设置 P4.1 为普通的输入引脚, P4CON.1 必须置为 0。

; 检查 GCHS 和 CHS[2:0]的状态。

B0BCLR FGCHS ; 若 CHS[2:0]指向 P4.1 (CHS[2:0] = 001B), GCHS=0。

;若 CHS[2:0]没有指向 P4.1,则忽略 GCHS 的状态。

;清P4CON。

B0BCLR P4CON.1 ; 使能 P4.1 的普通 I/O 功能。

; P4.1 设为输入模式。

B0BCLR P4M.1 ; 设置 P4.1 为输入模式。

例:设置 P4.1 为普通的输出模式, P4CON.1 必须置为 0。

; 检查 GCHS 和 CHS[2:0]的状态。

B0BCLR FGCHS ; 若 CHS[2:0]指向 P4.1 (CHS[2:0] = 001B), GCHS=0。

; 若 CHS[2:0]没有指向 P4.1,则忽略 GCHS 的状态。

;清 P4CON。

B0BCLR P4CON.1 ; 使能 P4.1 的普通 I/O 功能。

;设置 P4.1 为输出模式以避免误操作。

BOBSET P4.1 ; 设置 P4.1 为 1。

;或

B0BCLR P4.1 ; 设置 P4.1 为 0。

; P4.1 设为输出模式。

BOBSET P4M.1 ; 设置 P4.1 为输出模式。



# **8** 定时器

# 8.1 看门狗定时器

看门狗定时器 WDT 是一个 4 位二进制计数器,用于监控程序的正常执行。如果由于干扰,程序进入了未知状态,看门狗定时器溢出,系统复位。看门狗的工作模式由编译选项控制,其时钟源由内部低速 RC 振荡器(16KHz @3V,32KHz @5V)提供,它是将内部 RC 振荡器经 512 分频后送往看门狗定时器进行计数。

#### 看门狗溢出时间 = 8192 /内部低速振荡器周期(sec)

| VDD | 内部低速 RC 频率 | 看门狗溢出时间 |
|-----|------------|---------|
| 3V  | 16KHz      | 512ms   |
| 5V  | 32KHz      | 256ms   |

- \* 注:如果看门狗被置为"Always\_On"模式,那么看门狗在睡眠模式和绿色模式下仍然运行。
- \* 注:清看门狗定时器时建议使用宏指令@RST\_WDT。

看门狗清零的方法是对看门狗计数器清零寄存器 WDTR 写入清零控制字 5AH。

| 0CCH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| WDTR | WDTR7 | WDTR6 | WDTR5 | WDTR4 | WDTR3 | WDTR2 | WDTR1 | WDTR0 |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

: 清看门狗定时器。

#### 》 例:下面是对看门狗定时器操作的示例程序,在主程序的开始清看门狗定时器。

Main:

| MOV     | A, #5AH |
|---------|---------|
| B0MOV   | WDTR, A |
| CALL    | SUB1    |
| CALL    | SUB2    |
| <br>JMP | Main    |

▶ 例:用宏指令@RST\_WDT 清看门狗定时器。

Main:

@RST\_WDT ; 清看门狗定时器。

CALL SUB1
CALL SUB2
...
JMP Main

看门狗定时器应用注意事项如下:

- 对看门狗清零之前,检查 I/O 口的状态和 RAM 的内容可增强程序的可靠性;
- 不能在中断中对看门狗清零,否则无法侦测到主程序跑飞的状况;
- 程序中应该只在主程序中有一次清看门狗的动作,这种架构能够最大限度的发挥看门狗的保护功能。

#### 》 例:下面是对看门狗定时器操作的示例程序,在主程序的开始清看门狗定时器。

Main:

; 检查 I/O 口的状态。 ; 检查 RAM 的内容。

Err: JMP \$ ; I/O 口或 RAM 出错,不清看门狗等看门狗计时溢出。

Correct: ; I/O 口和 RAM 都正确,清看门狗定时器。

@RST\_WDT ; 在整个程序中只有一处地方清看门狗。

CALL SUB1
CALL SUB2
...
JMP Main



# 8.2 定时器T0

### 8.2.1 概述

二进制定时/计数器 T0 溢出(从 0FFH 到 00H)时, T0 继续计数并给出一个溢出信号触发 T0 中断。定时器 T0 的主要用途如下:

- 8位可编程定时计数器:根据选择的时钟频率周期性的产生中断请求;
- ☞ **绿色模式唤醒功能:** T0ENB = 1 时, T0 的溢出信号将系统从绿色模式下唤醒。



## 8.2.2 TOM模式寄存器

| 0D8H | Bit 7 | Bit 6   | Bit 5   | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|---------|---------|---------|-------|-------|-------|-------|
| TOM  | T0ENB | T0rate2 | T0rate1 | T0rate0 | -     | ı     | ı     | -     |
| 读/写  | R/W   | R/W     | R/W     | R/W     | -     | -     | -     | -     |
| 复位后  | 0     | 0       | 0       | 0       | -     | -     | -     | -     |

Bit [6:4] **TORATE[2:0]**: TO 分频选择位。

000 = fcpu/256; 001 = fcpu/128;

...;

110 = fcpu/4;

111 = fcpu/2.

Bit 7 **T0ENB:** T0 启动控制位。

0 = 禁止;

1 = 使能。



## 8.2.3 T0C计数寄存器

8 位计数寄存器 TOC 用于控制 TO 的中断间隔时间。

| 0D9H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| T0C  | T0C7  | T0C6  | T0C5  | T0C4  | T0C3  | T0C2  | T0C1  | T0C0  |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

TOC 初始值的计算公式如下:

TOC 初始值 = 256 - (TO 中断间隔时间 \* 输入时钟)

➢ 例:T0 的中断间隔时间为 10ms,高速时钟为内部 4MHz,Fcpu = Fosc/4,T0RATE = 010(Fcpu/64)。

TOC 初始值 = 256 - (TO 中断间隔时间 \* 输入时钟)

= 256 - (10ms \* 4MHz / 1 / 64)

= 256 - (10-2 \* 4 \* 106 / 1 / 64)

= 100

= 64H

#### T0 的中断间隔时间列表

| 10 10 11 10 10 10 10 10 10 10 10 10 10 1 |          |                       |                  |                          |                  |
|------------------------------------------|----------|-----------------------|------------------|--------------------------|------------------|
| T0RATE                                   | T0CLOCK  | 高速模式(Fcpu = 4MHz / 4) |                  | 低速模式(Fcpu = 32768Hz / 4) |                  |
|                                          |          | 最大间隔溢出时间              | 单步间隔时间 = max/256 | 最大间隔溢出时间                 | 单步间隔时间 = max/256 |
| 000                                      | Fcpu/256 | 65.536 ms             | 256 us           | 8000 ms                  | 31250 us         |
| 001                                      | Fcpu/128 | 32.768 ms             | 128 us           | 4000 ms                  | 15625 us         |
| 010                                      | Fcpu/64  | 16.384 ms             | 64 us            | 2000 ms                  | 7812.5 us        |
| 011                                      | Fcpu/32  | 8.192 ms              | 32 us            | 1000 ms                  | 3906.25 us       |
| 100                                      | Fcpu/16  | 4.096 ms              | 16 us            | 500 ms                   | 1953.125 us      |
| 101                                      | Fcpu/8   | 2.048 ms              | 8 us             | 250 ms                   | 976.563 us       |
| 110                                      | Fcpu/4   | 1.024 ms              | 4 us             | 125 ms                   | 488.281 us       |
| 111                                      | Fcpu/2   | 0.512 ms              | 2 us             | 62.5 ms                  | 244.141 us       |

## 8.2.4 TO 操作流程

T0 的操作流程如下:

● T0 停止计数,禁止 T0 中断功能,并清除 T0 中断请求标志。

BOBCLR FTOENB ;

BOBCLR FTOIEN ;禁止TO中断。 BOBCLR FTOIRQ ;清TOIRQ。

● 设置 T0 速率。

MOV A, #0xxx0000b ; TOM 的 bit4~bit6 将 TO 的速率控制在 x000xxxxb~x111xxxxb。

BOMOV TOM,A ; 关闭 TO 定时器。

● 设置 T0 的中断间隔时间。

MOV A,#7FH

BOMOV TOC,A ; 设置 TOC 的值。

● 设置 T0 的功能模式。

BOBSET FTOIEN ; 开启 TO 的中断功能。

● 开启 **T0** 定时器。

BOBSET FTOENB ;



## 8.2.5 T0 定时器的注意事项

当 TOC.7 由 1 变成 0 时,不管 TO 定时器是否在工作,TOIRQ 都要置 1,如果 TOIRQ = 0,则 TOC 的值由程序控制。在 TOC.7 由 1 变为 0 时,TOIRQ 可能会置 1,但这种情况会导致未知的 TO 中断发生。

➢ 例: TOC = 80H(TOC.7 = 1), TOIRQ = 0。当清除 TOC(TOC.7 = 0)后, TOIRQ 会置 1。

MOV A, #0 ; 清 T0C, T0C.7  $\Xi$  0。

B0MOV T0C, A ; T0IRQ  $\mathbb{Z}$  1。

BOBSET FTOIEN ; 使能 TO 的中断功能,程序调整到中断向量执行中断。

在系统运行过程中,如果必须改变 TOC 的值,那么就要在改变 TOC 的值之前禁止 TO 的中断功能。下面的示例程序就可以避开未知的 TO 中断。

▶ 例: TOC = 80H, TOIRQ = 0,程序清 TOC 时, TOIRQ 置 1。

BOBCLR FTOIEN ; 禁止 TO 的中断功能。

MOV A, #0 ; 清 TOC, TOC.7 清 0。

B0MOV T0C, A ; T0IRQ  $\mathbbm{Z}$  1。

BOBCLR FTOIRQ ; 清 TOIRQ。

BOBSET FTOIEN ; 使能 TO 的中断功能。

...

\* 注:首先禁止 T0 中断,然后再装载新的 T0C 值到 T0C 缓存器中,这样就可以避免未知的 T0 中断的发生。



# 8.3 定时/计数器TC0

#### 8.3.1 概述

定时/计数器 TC0 具有双时钟源,可根据实际需要选择内部时钟或外部时钟作为计时标准。其中,内部时钟源来自 Fcpu。外部时钟源 INT0 从 P0.0 端输入(下降沿触发)。寄存器 TC0M 控制 TC0 时钟源的选择。当 TC0 从 0FFH 溢出 到 00H 时,TC0 在继续计数的同时产生一个溢出信号,触发 TC0 中断请求。

以下是 TC0 的主要用途:

- ▼ 8位可编程定时器:根据选择的时钟信号,产生周期中断;
- 外部事件计数器:对外部事件计数;
- ☞ 蜂鸣器输出;
- PWM 输出。





#### 8.3.2 TC0M模式寄存器

| 0DAH | Bit 7  | Bit 6    | Bit 5    | Bit 4    | Bit 3  | Bit 2  | Bit 1  | Bit 0   |
|------|--------|----------|----------|----------|--------|--------|--------|---------|
| TC0M | TC0ENB | TC0rate2 | TC0rate1 | TC0rate0 | TC0CKS | ALOAD0 | TC0OUT | PWM0OUT |
| 读/写  | R/W    | R/W      | R/W      | R/W      | R/W    | R/W    | R/W    | R/W     |
| 复位后  | 0      | 0        | 0        | 0        | 0      | 0      | 0      | 0       |

Bit 0 **PWM0OUT:** PWM 输出控制位。

0 = 禁止 PWM 输出;

1 = 允许 PWM 输出, PWM 的输出占空比由 TC0OUT 和 ALOAD0 控制。

Bit 1 TC0OUT: TC0 溢出信号输出控制位,仅当 PWM0OUT = 0 时有效。

0 = 禁止, P5.4 作为普通的 I/O 口; 1 = 使能, P5.4 输出 TC0OUT 信号。

Bit 2 **ALOADO:** 自动装载控制位,仅当 PWM0OUT = 0 时有效。

0 = 禁止; 1 = 使能。

Bit 3 **TC0CKS:** TC0 时钟信号控制位。

0 = 内部时钟 Fcpu; 1 = 外部时钟信号。

Bit [6:4] **TC0RATE[2:0]:** TC0 分频选择位。

000 = fcpu/256. 001 = fcpu/128.

...

110 = fcpu/4. 111 = fcpu/2.

Bit 7 TC0ENB: TC0 启动控制位。

0 = 关闭 TC0 定时器; 1 = 开启 TC0 定时器。

注:若 TC0CKS=1,TC0 则用作外部事件计数器,此时不需考虑 TC0RATE 的设置。P0.0 无中断请求(P00IRQ=0)。



#### 8.3.3 TC0C计数寄存器

8 位计数寄存器 TC0C 用于控制 TC0 的中断间隔时间。

| 0DBH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| TC0C | TC0C7 | TC0C6 | TC0C5 | TC0C4 | TC0C3 | TC0C2 | TC0C1 | TC0C0 |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

TC0C 初始值的计算公式如下:

TC0C 初始值 = 256 - (TC0 中断间隔时间 \* 输入时钟)

▶ 例: TC0 中断间隔时间为 10ms,时钟源来自 Fcpu(TC0CKS=0,TC0X8=0),无 PWM 输出(PWM0=0),高速时钟 = 4MHz,Fcpu = Fosc/4,TC0RATE = 010(Fcpu/64)。

TCOC 初始值 = N - (TCO 中断间隔时间 \* 时钟信号) = 256 - (10ms \* 4MHz / 4 / 64) = 256 - (10-2 \* 4 \* 106 / 4 / 64) = 100 = 64H

#### TC0 中断间隔时间列表

|         | 311031.32.3.66 |           |                  |                          |                  |  |
|---------|----------------|-----------|------------------|--------------------------|------------------|--|
| TONDATE | TC0CLOCK       | 高速模式(     | Fcpu = 4MHz / 4) | 低速模式(Fcpu = 32768Hz / 4) |                  |  |
| ICURATE | ICUCLOCK       | 最大溢出间隔时间  | 单步间隔时间 = max/256 | 最大溢出间隔时间                 | 单步间隔时间 = max/256 |  |
| 000     | Fcpu/256       | 65.536 ms | 256 us           | 8000 ms                  | 31250 us         |  |
| 001     | Fcpu/128       | 32.768 ms | 128 us           | 4000 ms                  | 15625 us         |  |
| 010     | Fcpu/64        | 16.384 ms | 64 us            | 2000 ms                  | 7812.5 us        |  |
| 011     | Fcpu/32        | 8.192 ms  | 32 us            | 1000 ms                  | 3906.25 us       |  |
| 100     | Fcpu/16        | 4.096 ms  | 16 us            | 500 ms                   | 1953.125 us      |  |
| 101     | Fcpu/8         | 2.048 ms  | 8 us             | 250 ms                   | 976.563 us       |  |
| 110     | Fcpu/4         | 1.024 ms  | 4 us             | 125 ms                   | 488.281 us       |  |
| 111     | Fcpu/2         | 0.512 ms  | 2 us             | 62.5 ms                  | 244.141 us       |  |

\* 注:在 TC0 中断、Buzzer 输出模式下,TC0C 的值不能设为 0FFH,其有效范围为 00H~0FEH,但在 PWM 模式下并无此限制。



#### TC0R自动装载寄存器 8.3.4

TC0 的自动装载功能由 TC0M 的 ALOAD0 位控制。当 TC0C 溢出时, TC0R 的值自动装入 TC0C 中。这样, 用户就 不需要在中断中重新装载 TC0C。

| 0CDH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| TC0R | TC0R7 | TC0R6 | TC0R5 | TC0R4 | TC0R3 | TC0R2 | TC0R1 | TC0R0 |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

TCOR 初始值计算公式如下:

#### |TC0R 初始值 = N - (TC0 中断间隔时间 \* 输入时钟) |

N是 TC0 最大溢出值。TC0 的溢出时间和有效值见下表:

| TC0CKS | PWM0 | ALOAD0 | TC0OUT | N   | TC0R 有效值 | TC0R 二进制有效范围        |
|--------|------|--------|--------|-----|----------|---------------------|
|        | 0    | Х      | Х      | 256 | 00H~0FFH | 00000000b~1111111b  |
|        | 1    | 0      | 0      | 256 | 00H~0FFH | 00000000b~1111111b  |
| 0      | 1    | 0      | 1      | 64  | 00H~3FH  | xx000000b~xx111111b |
|        | 1    | 1      | 0      | 32  | 00H~1FH  | xxx00000b~xxx11111b |
|        | 1    | 1      | 1      | 16  | 00H~0FH  | xxxx0000b~xxxx1111b |
| 1      | -    | -      | -      | 256 | 00H~0FFH | 00000000b~1111111b  |

例: TC0 的间隔时间为 10ms,时钟源来自 Fcpu(TC0KS=0,TC0X8 = 0),无 PWM 输出(PWM0=0),高速时 钟为外部 4MHz, Fcpu=Fosc/4, TC0RATE=010 (Fcpu/64)。

注: 在 TC0 中断、Buzzer 输出模式时,TC0R 的值不能为 0FFH。其有效范围为 00H~0FEH,但在 PWM 模式下并无此限制。



## 8.3.5 TC0 时钟频率输出(蜂鸣器输出)

对 TC0 时钟频率进行适当设置可得到特定频率的蜂鸣器输出(TC0OUT),并通过引脚 P5.4 输出。单片机内部设置 TC0 的溢出频率经过 2 分频后作为 TC0OUT 的频率,即 TC0 每溢出 2 次 TC0OUT 输出一个完整的脉冲,此时,P5.4 的 I/O 功能自动被禁止。TC0OUT 输出波形如下:



若外部高速时钟选择 4MHz,系统时钟源采用外部时钟 Fosc/4,程序中设置 TC0RATE2~TC0RATE1 = 110, TC0C = TC0R = 131,则 TC0 的溢出频率为 2KHz,TC0OUT 的输出频率为 1KHz。下面给出范例程序。

#### ▶ 例:设置 TC0OUT (P5.4)。

| MOV<br>B0MOV               | A,#01100000B<br>TC0M,A        | ; TC0 速率 = Fcpu/4。                                                            |
|----------------------------|-------------------------------|-------------------------------------------------------------------------------|
| MOV<br>B0MOV<br>B0MOV      | A,#131<br>TC0C,A<br>TC0R,A    | ;自动装载参考值设置。                                                                   |
| BOBSET<br>BOBSET<br>BOBSET | FTC0OUT<br>FALOAD0<br>FTC0ENB | ; TC0 的输出信号由 P5.4 输出,禁止 P5.4 的普通 I/O 功能。<br>; 使能 TC0 自动装载功能。<br>; 开启 TC0 定时器。 |

\* 注:蜂鸣器的输出有效时,"PWM0OUT"必须被置为 "0"。



#### 8.3.6 TC0 定时器操作流程

TC0 定时器可用于定时器中断、事件计数、TC0OUT 和 PWM。下面分别举例说明。

● 停止 TC0 计数,禁止 TC0 中断,并清 TC0 中断请求标志。

B0BCLR FTC0ENB ; 停止 TC0 计数、TC0OUT 和 PWM。

BOBCLR FTCOIEN ;禁止TCO中断。 BOBCLR FTCOIRQ ;清TCOIRQ。

● 设置 TC0 的速率(不包含事件计数模式)。

MOV A, #0xxx0000b ;TC0M 的 bit4~bit6 将 TC0 的速率控制在 x000xxxxb~x111xxxxb。

BOMOV TCOM,A ; 禁止 TCO 中断。

● 设置 TC0 的时钟源。

;选择 TC0 内部/外部时钟源。

BOBCLR FTCOCKS ; 内部时钟。

或

BOBSET FTCOCKS ; 外部时钟。

● 设置 TC0 的自动装载模式。

BOBCLR FALOADO ; 禁止 TCO 自动装载功能。

或

或

或

或

BOBSET FALOADO ; 使能 TCO 自动装载功能。

● 设置 TC0 中断间隔时间,TC0OUT(Buzzer) 频率或 PWM 占空比。

;设置 TC0 中断间隔时间,TC0OUT(Buzzer)频率或 PWM 占空比。

MOV A,#7FH ; TC0 的模式决定 TC0C 和 TC0R 的值。

BOMOV TCOC,A ; 设置 TCOC 的值。

BOMOV TCOR,A ; 在自动装载模式或 PWM 模式下设置 TCOR 的值。

; PWM 模式下设置 PWM 的周期。

B0BCLR FALOAD0 ; ALOAD0, TC0OUT = 00, PWM 周期=0~255。

B0BCLR FTC0OUT

或 B0BCLR FALOAD0 ; ALOAD0, TC0OUT = 01, PWM 周期=0~63。

B0BSET FTC0OUT

B0BSET FALOAD0 ; ALOAD0,TC0OUT = 10, PWM 周期=0~31。

, ALOADO, TOOOT = 10, T WW

B0BCLR FTC0OUT

B0BSET FALOAD0 ; ALOAD0,TC0OUT = 11, PWM 周期=0~15。

B0BSET FTC0OUT

● 设置 TC0 的模式。

BOBSET FTCOIEN ; 使能 TCO 中断。

B0BSET FTC0OUT ; 使能 TC0OUT (Buzzer) 功能。

或

B0BSET FPWM0OUT ; 使能 PWM。

● 开启 **TC0** 定时器。

BOBSET FTCOENB ;



#### 8.3.7 TC0 定时器注意事项

当 TC0C 的值由 0FFH 变成非 0FFH 时,不管 TC0 是否在工作,TC0IRQ 都要置 1。如果 TC0IRQ = 0 且 TC0C≠0FFH 时,TC0IRQ 可能会置 1。这样就会导致未知的 TC0 中断发生。

▶ 例: TCOC = 0FFH, TC0IRQ = 0, 当由程序清 TC0C(TC0C = 0)时, TC0IRQ = 1。

MOV A, #0 ; 清 TC0C。 B0MOV TC0C, A ; TC0IRQ 置 1。

BOBSET FTCOIEN ; 使能 TCO 的中断功能,程序跳转到中断向量执行中断。

如果在系统工作时必须改变 TCOC 的值,就要在改变 TCOC 的值之前禁止 TCO 中断(TC0IEN = 0),这样就可以避免未知 TCO 中断。示例程序如下:

▶ 例: TC0C = 0FFH,TC0IRQ = 0,禁止 TC0 中断后清 TC0C。

BOBCLR FTC0IEN ; 禁止 TC0 中断。

MOV A, #0 ; 清 TC0C。 B0MOV TC0C, A ; TC0IRQ 置 1。

B0BCLR FTC0IRQ ; 清 TC0IRQ。

BOBSET FTCOIEN ; 使能 TCO 中断。

...

\* 注:首先禁止 TC0 中断,然后再装载新的 TC0C 值到 TC0C 缓存器。这样可以避免进入未知的 TC0 中断。

☀ 注: 在 TC0 中断、buzzer 输出模式时,TC0C 和 TC0R 的值不能是 0FFH,TC0C 和 TC0R 的有效范围是 00H~0FEH。但在 PWM 模式下并无此限制。



# 8.4 定时/计数器TC1

## 8.4.1 概述

定时/计数器 TC1 具有双时钟源,可根据实际需要选择内部时钟或外部时钟作为计时标准。其中,内部时钟源来自 Fcpu。外部时钟源 INT1 从 P0.1 端输入(下降沿触发)。寄存器 TC1M 控制 TC1 时钟源的选择。当 TC1 从 0FFH 溢出 到 00H 时,TC1 在继续计数的同时产生一个溢出信号,触发 TC1 中断请求。

TC1 的主要功能如下:

- ▼ 8位可编程定时器:根据选择的时钟信号,产生周期中断;
- 外部事件计数器:对外部事件计数:
- ☞ Buzzer 输出;
- PWM 输出。





#### 8.4.2 TC1M模式寄存器

| 0DCH | Bit 7  | Bit 6    | Bit 5    | Bit 4    | Bit 3  | Bit 2  | Bit 1  | Bit 0   |
|------|--------|----------|----------|----------|--------|--------|--------|---------|
| TC1M | TC1ENB | TC1rate2 | TC1rate1 | TC1rate0 | TC1CKS | ALOAD1 | TC10UT | PWM1OUT |
| 读/写  | R/W    | R/W      | R/W      | R/W      | R/W    | R/W    | R/W    | R/W     |
| 复位后  | 0      | 0        | 0        | 0        | 0      | 0      | 0      | 0       |

Bit 0 **PWM1OUT:** PWM 输出控制位。

0 = 禁止 PWM 输出;

1 = 允许 PWM 输出, PWM 输出占空比由 TC1OUT 和 ALOAD1 控制。

Bit 1 TC1OUT: TC1 溢出信号输出控制位。仅当 PWM1OUT = 0 时有效。

0 = 禁止, P5.3 作为普通的 I/O 口;

1 = 使能, P5.3 输出 TC1OUT 信号。

Bit 2 **ALOAD1:** 自动装载控制位。仅当 PWM1OUT = 0 时有效。

0 = 禁止;

1 = 使能。

Bit 3 TC1CKS: TC1 时钟源控制位。

0 = 内部时钟(Fcpu);

1 = 外部时钟, 由 P0.1/INT1 输入。

Bit [6:4] **TC1RATE[2:0]**: TC1 分频选择位。

000 = fcpu/256;

001 = fcpu/128;

...;

110 = fcpu/4;

111 = fcpu/2.

Bit 7 TC1ENB: TC1 启动控制位。

0 = 禁止 TC1 定时器;

1 = 开启 TC1 定时器。

\* 注:若 TC1CKS=1, 则 TC1 用作外部事件计数器,此时不需要考虑 TC1RATE 的设置,P0.1 无中断请求(P0.1IRQ=0)。



#### 8.4.3 TC1C计数寄存器

8 位计数寄存器 TC1C 控制 TC1 的中断间隔时间。

| 0DDH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| TC1C | TC1C7 | TC1C6 | TC1C5 | TC1C4 | TC1C3 | TC1C2 | TC1C1 | TC1C0 |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

TC1C 初始值的计算公式如下:

TC1C 初始值 = 256 - (TC1 中断间隔时间 \* 输入时钟)

▶ 例: TC1 中断间隔时间为 10ms,时钟源来自 Fcpu(TC1CKS = 0, TC1X8 = 0), 无 PWM 输出(PWM1 = 0), 高速时钟 = 4MHz, Fcpu=Fosc/4, TC1RATE=010 (Fcpu/64)。

TC1C 初始值 = 256 - (TC1 中断间隔时间 \* 输入时钟)

= 256 - (10ms \* 4MHz / 4 / 64)

= 256 - (10-2\*4\*106/4/64)

= 100

= 64H

#### TC1 中断间隔时间列表

|         | O MERT INJUSTACE |           |                  |          |                    |
|---------|------------------|-----------|------------------|----------|--------------------|
| TC1DATE | TC1CLOCK         | 高速模式(     | Fcpu = 4MHz / 4) | 低速模式(F   | cpu = 32768Hz / 4) |
| ICIKAIE | ICICLOCK         | 最大溢出间隔时间  | 单步间隔时间 = max/256 | 最大溢出间隔时间 | 单步间隔时间 = max/256   |
| 000     | Fcpu/256         | 65.536 ms | 256 us           | 8000 ms  | 31250 us           |
| 001     | Fcpu/128         | 32.768 ms | 128 us           | 4000 ms  | 15625 us           |
| 010     | Fcpu/64          | 16.384 ms | 64 us            | 2000 ms  | 7812.5 us          |
| 011     | Fcpu/32          | 8.192 ms  | 32 us            | 1000 ms  | 3906.25 us         |
| 100     | Fcpu/16          | 4.096 ms  | 16 us            | 500 ms   | 1953.125 us        |
| 101     | Fcpu/8           | 2.048 ms  | 8 us             | 250 ms   | 976.563 us         |
| 110     | Fcpu/4           | 1.024 ms  | 4 us             | 125 ms   | 488.281 us         |
| 111     | Fcpu/2           | 0.512 ms  | 2 us             | 62.5 ms  | 244.141 us         |

☀ 注:在 TC1 中断、buzzer 输出模式下时,TC1C 和 TC1R 的值不能为 0FFH,其有效范围时 00H~0FEH,但在 PWM 模式下并 无此限制。



#### 8.4.4 TC1R自动装载寄存器

TC1 的自动装载功能由 TC1M 的 ALOAD1 位控制。当 TC1C 溢出时,TC1R 的值自动装入 TC1C 中。这样,用户在 使用的过程中就不需要在中断中复位 TC1C。

| 0DEH | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| TC1R | TC1R7 | TC1R6 | TC1R5 | TC1R4 | TC1R3 | TC1R2 | TC1R1 | TC1R0 |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

TC1R 初始值计算公式如下:

#### |TC1R 初始值 = N - (TC1 中断间隔时间 \* 输入时钟)

N是 TC1 最大溢出值。TC1 的溢出时间和有效值见下表:

| TC1CKS | PWM1 | ALOAD1 | TC10UT | N   | TC1R 有效范围 | TC1R 二进制有效范围        |
|--------|------|--------|--------|-----|-----------|---------------------|
|        | 0    | Х      | Х      | 256 | 00H~0FFH  | 00000000b~1111111b  |
|        | 1    | 0      | 0      | 256 | 00H~0FFH  | 00000000b~1111111b  |
| 0      | 1    | 0      | 1      | 64  | 00H~3FH   | xx000000b~xx111111b |
|        | 1    | 1      | 0      | 32  | 00H~1FH   | xxx00000b~xxx11111b |
|        | 1    | 1      | 1      | 16  | 00H~0FH   | xxxx0000b~xxxx1111b |
| 1      | -    | -      | 1      | 256 | 00H~0FFH  | 00000000b~1111111b  |

例: TC1 的间隔时间为 10ms,时钟源来自 Fcpu(TC1CKS=0,TC1X8 = 0),无 PWM 输出(PWM1=0),高速 时钟为外部 4MHz,Fcpu = Fosc/4,TC1RATE = 010(Fcpu/64)。

> TC1R = N - (TC1 中断间隔时间 \* 输入时钟) = 256 - (10ms \* 4MHz / 4 / 64)= 256 - (10-2 \* 4 \* 106 / 4 / 64) = 100= 64H

注: 在 TC1 中断、buzzer 输出模式时,TC1R 的值不能为 0FFH,其有效范围时 00H~0FEH,但在 PWM 模式下并无此限制。



## 8.4.5 TC1 时钟频率输出(蜂鸣器输出)

对 TC1 时钟频率进行适当设置可得到特定频率的蜂鸣器输出(TC1OUT),并通过引脚 P5.3 输出。单片机内部设置 TC1 的溢出频率经过 2 分频后作为 TC1OUT 的频率,即 TC1 每溢出 2 次 TC1OUT 输出一个完整的脉冲,此时,P5.3 的 I/O 功能自动被禁止。TC1OUT 输出波形如下:



若外部高速时钟选择 4MHz,系统时钟源采用外部时钟 Fosc/4,程序中设置 TC1RATE2~TC1RATE1 = 110, TC1C = TC1R = 131,则 TC1 的溢出频率为 2KHz,TC1OUT 的输出频率为 1KHz。下面给出范例程序。

#### ▶ 例:设置 TC1OUT (P5.3)。

| MOV<br>B0MOV               | A,#01100000B<br>TC1M,A        | ; TC1 速率 = Fcpu/4。                                                            |
|----------------------------|-------------------------------|-------------------------------------------------------------------------------|
| MOV<br>B0MOV<br>B0MOV      | A,#131<br>TC1C,A<br>TC1R,A    | ; 自动装载参考值设置。                                                                  |
| BOBSET<br>BOBSET<br>BOBSET | FTC1OUT<br>FALOAD1<br>FTC1ENB | ; TC1 的输出信号由 P5.3 输出,禁止 P5.3 的普通 I/O 功能。<br>; 使能 TC1 自动装载功能。<br>; 开启 TC1 定时器。 |

\* 注:蜂鸣器的输出有效时, "PWM1OUT"必须被置为"0"。



#### 8.4.6 TC1 操作流程

TC1 定时器可用于定时器中断、事件计数、TC1OUT 和 PWM。下面分别举例说明。

停止 TC1 计数,禁止 TC1 中断并清 TC1 中断请求标志。

**B0BCLR** FTC1ENB :停止 TC1 计数、TC1OUT 和 PWM。

;禁止 TC1 中断。 **B0BCLR** FTC1IEN **B0BCLR** ;清TC1IRQ。 FTC1IRQ

设置 TC1 的速率 (不包含事件计数模式)。

MOV A, #0xxx0000b :TC1M 的 bit4~bit6 将 TC1 的速率控制在 x000xxxxb~x111xxxxb。

**B0MOV** TC1M,A ;禁止 TC1 中断。

设置 TC1 的时钟源。

;选择 TC1 的时钟源。

**B0BCLR** FTC1CKS ;内部时钟。

或

**BOBSET** FTC1CKS ;外部时钟。

设置 TC1 的自动装载模式。

**B0BCLR** FALOAD1 ;禁止 TC1 自动装载功能。

或

或

或

或

**B0BSET** FALOAD1 ; 使能 TC1 自动装载功能。

设置 TC1 中断间隔时间,TC1OUT(Buzzer) 频率或 PWM 占空比。

:设置 TC1 中断间隔时间, TC1OUT (Buzzer) 频率或 PWM 占空比。

MOV A,#7FH ; TC1 的模式决定 TC1C 和 TC1R 的值。

**B0MOV** TC1C,A ;设置 TC1C 的值。

**B0MOV** TC1R,A ;在自动装载模式或PWM模式下设置TC1R的值。

; PWM 模式下设置 PWM 周期。

**B0BCLR** ; ALOAD1, TC1OUT = 00, PWM 周期 = 0~255。 FALOAD1

**B0BCLR** FTC10UT

**B0BCLR** FALOAD1

; ALOAD1, TC1OUT = 01, PWM 周期 = 0~63。

**BOBSET** FTC1OUT

; ALOAD1, TC1OUT = 10, PWM 周期 = 0~31。 **B0BSET** FALOAD1

**B0BCLR** FTC10UT

或

FALOAD1 **B0BSET** ; ALOAD1, TC1OUT = 11, PWM 周期 = 0~15

> **B0BSET** FTC1OUT

设置 TC1 的模式。

**BOBSET** FTC1IEN ; 使能 TC1 中断。

或

; 开启 TC1OUT (Buzzer) 功能。 **B0BSET** FTC10UT

**BOBSET** FPWM1OUT ; 开启 PWM。

开启 TC1 定时器。

**BOBSET** FTC1ENB



#### 8.4.7 TC1 定时器注意事项

当 TC1C 的值由 0FFH 变成非 0FFH 时,不管 TC1 是否在工作,TC1IRQ 都要置 1。如果 TC1IRQ = 0 且 TC1C≠0FFH 时,TC1IRQ 可能会置 1。这样就会导致未知的 TC1 中断发生。

➢ 例: TC1C = 0FFH, TC1IRQ = 0, 当由程序清 TC1C(TC1C = 0)时, TC1IRQ = 1。

MOV A, #0 ; 清 TC1C。 B0MOV TC1C, A ; TC1IRQ 置 1。

BOBSET FTC1IEN ; 使能 TC1 的中断功能,程序跳转到中断向量执行中断。

如果在系统工作时必须改变 TC1C 的值,就要在改变 TC1C 的值之前禁止 TC1 中断(TC1IEN = 0),这样就可以避免未知的 TC1 中断。示例程序如下:

▶ 例: TC1C = 0FFH, TC1IRQ = 0,禁止 TC1 中断后清 TC1C。

BOBCLR FTC1IEN ; 禁止 TC1 中断。

MOV A, #0 ; 清 TC1C。 B0MOV TC1C, A ; TC1IRQ 置 1。

B0BCLR FTC1IRQ ; 清 TC1IRQ。

BOBSET FTC1IEN ; 使能 TC1 中断。

...

\* 注:首先禁止 TC1 中断,然后再装载新的 TC1C 值到 TC1C 缓存器。这样可以避免进入未知的 TC1 中断。

注: 在 TC1 中断、buzzer 输出模式时, TC1C 和 TC1R 的值不能是 0FFH, TC1C 和 TC1R 的有效范围是 00H~0FEH。但在 PWM 模式下并无此限制。



# 8.5 PWM0 模式

#### 8.5.1 概述

PWM 信号通过 PWM0OUT (P5.4 引脚)输出, TC0OUT 和 ALOAD0 标志位控制 PWM 输出的阶数(256、64、32 和 16)。8 位计数器 TC0C 计数过程中不断与 TC0R 相比较,当 TC0C 的值增加到与 TC0R 相等时,PWM 输出低电平,当 TC0C 的值溢出重新回到 0 时,PWM 被强制输出高电平。PWM0 输出占空比 = TC0R/ 256、64、32、16。

注:在 PWM 输出模式下,TC0C 和 TC0R 的值可以是 0FFH,但在 TC0 中断下,TC0C 和 TC0R 的有效值的范围为 00H~0FEH。

| ALOAD0 | TC0OUT | PWM 占空比范围     | TC0C 有效值 | TC0R 有效值 | MAX. PWM 频率<br>(Fcpu = 4MHz) | 备注          |
|--------|--------|---------------|----------|----------|------------------------------|-------------|
| 0      | 0      | 0/256~255/256 | 00H~0FFH | 00H~0FFH | 7.8125K                      | 每计数 256 次溢出 |
| 0      | 1      | 0/64~63/64    | 00H~3FH  | 00H~3FH  | 31.25K                       | 每计数 64 次溢出  |
| 1      | 0      | 0/32~31/32    | 00H~1FH  | 00H~1FH  | 62.5K                        | 每计数 32 次溢出  |
| 1      | 1      | 0/16~15/16    | 00H~0FH  | 00H~0FH  | 125K                         | 每计数 16 次溢出  |

#### PWM 输出占空比随 TC0R 的变化而变化: 0/256~255/256。





#### 8.5.2 TC0IRQ和PWM0 输出占空比



## 8.5.3 PWM0 编程举例

▶ 例: PWM0 输出设置。外部高速振荡器输出频率= 4MHZ, Fcpu = Fosc/4, PWM0 输出占空比= 30/256, 输出频率 1KHZ, PWM 时钟源来自外部时钟, TC0 速率= Fcpu/4, TC0RATE2~TC0RATE0 = 110, TC0C = TC0R = 30。

MOV A,#01100000B B0MOV TC0M,A ; TC0 速率=Fcpu/4。

MOV A,#30 ; PWM 输出占空比=30/256。

BOMOV TCOC,A BOMOV TCOR,A

BOBCLR FTC0OUT ; 占空比变化范围: 0/256~255/256。

B0BCLR FALOAD0 B0BSET FPWM0OUT ; PWM0 输出至 P5.4,禁止 P5.4 I/O 功能。

BOBSET FTC0ENB ; 使能 TC0 定时器。

- \* 注:TC0R 为只写寄存器,不能用 INCMS 和 DECMS 指令对其进行操作。
- 例:改变 TC0R 的内容。

MOV A, #30H B0MOV TCOR, A INCMS BUF0 NOP B0MOV A BUF0

BOMOV A, BUFO BOMOV TCOR, A

\* 注: PWM0 可以在中断下工作。



#### 8.5.4 PWM0 占空比注意事项

在 PWM 模式下,系统会随时比较 TC0C 和 TC0R 的值。如果 TC0C<TC0R, PWM 输出高电平, 而当 TC0C ≧ TC0R 时则输出低电平。当 TC0C 发生改变的时候,PWM 的占空比也随着改变,如果 TC0R 保持恒定,那么 PWM 输出波形也保持稳定。



上图所示是 TCOR 恒定时的波形。每当 TCOC 溢出时, PWM 都输出高电平, TCOC ≥ TCOR 时, PWM 输出低电平。

\* 注: 若要在程序处理过程中设置 PWM 的占空比,必须得在下一个周期开始时进行。

★ 注:在 PWM 输出模式下,TC0C 和 TC0R 的值可以是 0FFH。

下面所示是 TCOR 发生变化时对应的波形图:



在 period 2 和 period 4 中,设置新的占空比(TC0R),但 period 2 和 period 4 输出波形却是不正确的。在 period 2 中,TC0R 的新值会比旧值略大,如果在 PWM 输出低电平后设置 TC0R 的新值,系统就会获得 TC0C < TC0R 的结果,PWM 输出高电平。在一个周期内两次输出高电平,波形图也不是预期的。直到下一个周期,PWM 才会正确输出。在 period 4 中,TC0R 的新值会比旧值略小,在 PWM 输出低电平之前设置 TC0R 的新值,系统就会获得 TC0C ≥ TC0R 的结果,PWM 输出低电平。在同一个周期内,高电平的占空比小于上一个周期,但却大于高电平占空比的正确值。



虽然不正确的波形图只会在一个周期内存在,但仍然会影响 PWM 工作的精确度并导致外部负载操作出错。在 TC0 定时器溢出后装载 TC0R 的新值时,利用 TC0IRQ 的状态来确定 TC0 定时器是否溢出。若 TC0IRQ = 1,则开始装载 TC0R 的新值,这样可以避免出现未知的 PWM 输出。

#### ▶ 例:利用 TC0 中断请求标志来决定是否装载 TC0R 的新值以改变 PWM 的输出占空比。

MAIN:

BOMOV TCORBUF, A ; 装载 PWM 占空比的新值到 TCORBUF。

...

INT\_SER:

… ; 保存 ACC 和 PFLAG。

B0BTS1 FTC0IRQ JMP INT\_SER90

BOMOV A, TCORBUF ; TCO 中断时,更新 TCOR。 BOMOV TCOR, A

..

INT\_SER90:

… ; 恢复 ACC 和 PFLAG。

RETI



# 8.6 PWM1 模式

#### 8.6.1 概述

PWM 信号通过 PWM1OUT (P5.3 引脚)输出,位 TC1OUT 和 ALOAD1 控制 PWM 输出的阶数(256、64、32 和 16)。8 位计数器 TC1C 计数过程中不断与 TC1R 相比较,当 TC1C 的值增加到与 TC1R 相等时,PWM 输出低电平,当 TC1C 的值溢出重新回到 0 时,PWM 被强制输出高电平。PWM1 输出占空比 = TC1R/256、64、32、16。

#### 注:在 PWM 输出模式下,TC1C 和 TC1R 的值可以是 0FFH,但在 TC1 中断下,TC1C 和 TC1R 的有效值的范围为 00H~0FEH。

| ALOAD1 | TC1OUT | PWM 占空比范围     | TC1C 有效值 TC1R 有效值 |          | MAX. PWM 频率<br>(Fcpu = 4MHz) | 备注          |
|--------|--------|---------------|-------------------|----------|------------------------------|-------------|
| 0      | 0      | 0/256~255/256 | 00H~0FFH          | 00H~0FFH | 7.8125K                      | 每计数 256 次溢出 |
| 0      | 1      | 0/64~63/64    | 00H~3FH           | 00H~3FH  | 31.25K                       | 每计数 64 次溢出  |
| 1      | 0      | 0/32~31/32    | 00H~1FH           | 00H~1FH  | 62.5K                        | 每计数 32 次溢出  |
| 1      | 1      | 0/16~15/16    | 00H~0FH           | 00H~0FH  | 125K                         | 每计数 16 次溢出  |

#### PWM 输出占空比随 TC1R 的变化而变化: 0/256~255/256。





#### 8.6.2 TC1IRQ和PWM占空比





## 8.6.3 PWM1 编程举例

▶ 例: PWM1 输出设置。外部高速振荡器输出频率 = 4MHZ, Fcpu = Fosc/4, PWM1 输出占空比 = 30/256, 输出频率 1KHZ, PWM1 时钟源来自外部时钟, TC1 速率 = Fcpu/4, TC1RATE2~TC1RATE0 = 110, TC1C = TC1R = 30。

MOV A,#01100000B B0MOV TC1M,A ; TC1 速率=Fcpu/4。

MOV A,#30 ; PWM 输出占空比=30/256。

BOMOV TC1C,A BOMOV TC1R,A

B0BCLR FTC1OUT ; 占空比变化范围: 0/256~255/256。

BOBCLR FALOAD1

BOBSET FPWM1OUT ; PWM1 输出至 P5.3,禁止 P5.3 I/O 功能。

BOBSET FTC1ENB ; 使能 TC1 定时器。

- ¥ 注:TC1R 为只写寄存器,不能用 INCMS 和 DECMS 指令对其进行操作。
- ▶ 例:改变 TC1R 的内容。

MOV A, #30H B0MOV TC1R, A

INCMS BUF0 NOP B0MOV A, BUF0 B0MOV TC1R, A

\* 注:PWM1 可以在中断下工作。



#### 8.6.4 PWM1 占空比注意事项

在 PWM 模式下,系统会随时比较 TC1C 和 TC1R 的值。如果 TC1C<TC1R, PWM 输出高电平,而当 TC1C ≧ TC1R 时则输出低电平。当 TC1C 发生改变的时候,PWM 的占空比也随着改变,如果 TC1R 保持恒定,那么 PWM 输出波形也保持稳定。



上图所示是 TC1R 恒定时的波形。每当 TC1C 溢出时, PWM 都输出高电平, TC1C ≥ TC1R 时, PWM 即输出低电平。

\* 注: 若要在程序处理过程中设置 PWM 的占空比,必须得在下一个周期开始时进行。

★ 注:在 PWM1 输出模式下,TC1C 和 TC1R 的值可以是 0FFH,

下面所示是 TC1R 发生变化时对应的波形图:



在 period 2 和 period 4 中,设置新的占空比(TC1R),但 period 2 和 period 4 输出波形却是不正确的。在 period 2 中,TC1R 的新值会比旧值略大,如果在 PWM 输出低电平后设置 TC1R 的新值,系统就会获得 TC1C < TC1R 的结果,PWM 输出高电平。在一个周期内两次输出高电平,波形图也不是预期的。直到下一个周期,PWM 才会正确输出。在 period 4 中,TC1R 的新值会比旧值略小,在 PWM 输出低电平之前设置 TC1R 的新值,系统就会获得 TC1C ≥ TC1R 的结果,PWM 输出低电平。在同一个周期内,高电平的占空比小于上一个周期,但却大于高电平占空比的正确值。



虽然不正确的波形图只会在一个周期内存在,但仍然会影响 PWM 工作的精确度并导致外部负载操作出错。在 TC1 定时器溢出后装载 TC1R 的新值时,利用 TC1IRQ 的状态来确定 TC1 定时器是否溢出。若 TC1IRQ = 1,则开始装载 TC1R 的新值,这样可以避免出现未知的 PWM 输出。

#### 》 例: 利用 TC1 中断请求标志来决定是否装载 TC1R 的新值以改变 PWM1 的输出占空比。

MAIN:

BOMOV TC1RBUF, A ; 装载 PWM1 占空比的新值到 TC1RBUF。

...

INT\_SER:

… ; 保存 ACC 和 PFLAG。

B0BTS1 FTC1IRQ
JMP INT\_SER90
B0MOV A, TC1RBUF

B0MOV A, TC1RBUF ; TC1 中断时,更新 TC1R。 B0MOV TC1R, A

. . .

INT\_SER90:

… ; 恢复 ACC 和 PFLAG。

RETI



# 9 串行收发器SIO

# 9.1 概述

串行输入/输出SIO收发器允许高速同步数据在SN8P2700A系列单片机和外围装置之间或者几个SN8P2700A装置之间传送。外围装置可以是:串行EEPROMs,移位寄存器,显示驱动芯片等。

SN8P2700A的SIO特性包括:

- 全双工3线同步传输;
- TX/RX 模式或单向 TX 模式;
- 主控模式(SCK 为时钟输出)或从动模式(SCK 为时钟输入);
- LSB 数据优先传送;
- 在多路从动装置应用时,SO(P5.2)是可编程漏极开路输出引脚;
- 主控模式时可设置数据传输速率;
- 传送结束时产生 SIO 中断。

寄存器SIOM用来控制SIO功能,如发送/接收、时钟速率、触发边沿等。通过设置寄存器SIOM的SENB和START位,SIO就可自动发送和接收8位数据。SIOB是一个8位数据缓存器,用于存储发送/接收的数据,SIOC和SIOR具有自动装载功能,能够产生SIO的时钟源。3位的I/O计数器可以监控SIO的操作,每接收/发送8位数据后,会产生一个中断请求。一次发送或接收结束后,SIO电路将自动禁止,可以通过重新编程SIOM寄存器启动下一次的数据传输。



SIO 接口电路图



系统发送时使用一次缓存,而在接收时使用两次缓存。也就是说在整个移位周期结束前,新的数据不能写入SIOB数据寄存器中;而在接收数据时,在新的数据完全移入前,必须从SIOB数据寄存器中读出接收的数据,否则,前一个数据将会丢失。下图是一个典型的单片机之间的数据通信。由主控单片机发送SCK启动数据传输,两个单片机必须有相同的时钟沿触发方式,并将在同一时刻发送和接收数据。



SIO 数据传送示意图

SIO 数据传输的时序图如下:



SIO 数据传输时序图

注:在任何模式下,SIO 总是在 SCK 时钟前沿发送数据,在 SCK 时钟后沿接收数据。



# 9.2 SIOM模式寄存器

#### $SIOM = 0000 \times 000$

| 0B4H | Bit 7 | Bit 6 | Bit 5  | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|--------|--------|-------|-------|-------|-------|
| SIOM | SENB  | START | SRATE1 | SRATE0 | -     | SCKMD | SEDGE | TXRX  |
| 读/写  | R/W   | R/W   | R/W    | R/W    | -     | R/W   | R/W   | R/W   |
| 复位后  | 0     | 0     | 0      | 0      | -     | 0     | 0     | 0     |

Bit 7 **SENB**: SIO 功能控制位。

0 = 禁止(P5.0~P5.2 作为普通输入输出引脚);

1 = 使能 (P5.0~P5.2 作为 SIO 引脚)。

Bit 6 **START**: SIO 状态控制位。

0 = 传送结束; 1 = 传送过程中。

Bit [5:4] SRATE1,0: SIO 传送时钟分频位,当 SCKMD=1,这两个位的功能是无效的。

00 = Fcpu;

01 = Fcpu/32;

10 = Fcpu/16;

11 = Fcpu/8.

Bit 2 **SCKMD**: SIO 时钟模式选择位。

0 = 内部时钟; 1 = 外部时钟。

Bit 1 SEDGE: SIO 传送时钟沿选择位。

0 = 下降沿; 1 = 上升沿。

Bit 0 TXRX: SIO 传输方向选择位。

0 = 只接收;

1 = 既发送也接收。

- \* 注 1:在外部时钟模式时,若 SCKMD=1,则 SIO 处于从动模式,内部时钟时,若 SCKMD = 0 则为主控模式。
- \* 注 2: 不能同时设置 SENB 和 START 位为 1, 否则会导致 SIO 传送出错。

SIO 功能是与 P5 口共用: P5.0/SCK、P5.1/SI、P5.2/SO。下表列出了在使能或禁止 SIO 功能时, P5[2:0]的 I/O 口的模式状态和设置。

| SENB=1(使能      | SENB=1(使能 SIO 功能)         |                            |  |  |  |  |  |  |  |  |  |  |
|----------------|---------------------------|----------------------------|--|--|--|--|--|--|--|--|--|--|
| P5.0/SCK       | (SCKMD=1) SIO 时钟来自外部时钟    | P5.0 被自动设为输入模式,不管 P5M 如何设置 |  |  |  |  |  |  |  |  |  |  |
| F5.0/3CK       | (SCKMD=0) SIO 时钟源来自内部时钟   | P5.0 被自动设为输出模式,不管 P5M 如何设置 |  |  |  |  |  |  |  |  |  |  |
| P5.1/SI        | P5.1 必须设为输入模式, 否则 SIO 功能会 | 5.1 必须设为输入模式,否则 SIO 功能会出错  |  |  |  |  |  |  |  |  |  |  |
| P5.2/SO        | (TXRX=1) SIO = 发送/接收      | P5.2 被自动设为输出模式,不管 P5M 如何设置 |  |  |  |  |  |  |  |  |  |  |
| F3.2/30        | (TXRX=0) SIO = 接收         | P5.2 被自动设为输入模式,不管 P5M 如何设置 |  |  |  |  |  |  |  |  |  |  |
| SENB=0 (禁止     | 上 SIO 功能)                 |                            |  |  |  |  |  |  |  |  |  |  |
| P5.0/P5.1/P5.2 | 禁止 SIO 功能时,自动由 P5M 完全控制   | J P5[2:0]的 I/O 模式          |  |  |  |  |  |  |  |  |  |  |

# 9.3 SIOB数据缓存器

#### SIOB = 0000 0000

| 0.00 |       |       |       |       |       |       |       |       |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0B6H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| SIOB | SIOB7 | SIOB6 | SIOB5 | SIOB4 | SIOB3 | SIOB2 | SIOB1 | SIOB0 |
| 读/写  | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

SIOB是SIO的数据缓存器,存储串行发送/接收的数据。



# 9.4 SIOR寄存器

#### SIOR = 0000 0000

| 0B5H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| SIOR | SIOR7 | SIOR6 | SIOR5 | SIOR4 | SIOR3 | SIOR2 | SIOR1 | SIOR0 |
| 读/写  | W     | W     | W     | W     | W     | W     | W     | W     |
| 复位后  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

寄存器SIOR用于SIO的自动装载,类似于后置分频器,能够提高SIO的时钟精度。用户可对SIOR进行写操作,从而 控制SIO的通信速率。SIO的时钟频率计算如下:

SCK 频率 = SIO 速率 / (256 - SIOR))2

SIOR = 256 - (1 / ( SCK 频率) \* SIO 速率)

例:设置 SIO 时钟频率为 5KHz,Fosc = 3.58MHz,SIO's 速率 = Fcpu = Fosc/4。

SIOR = 256 - (1/(5KHz) \* 3.58MHz/4)

= 256 - (0.0002\*895000)

= 256 - 179

= 77

例: 主控模式下,上升沿触发时发送/接收数据。

MOV A,TXDATA

**B0MOV** SIOB,A MOV A,#0FFH

**B0MOV** SIOR,A

A,#10000011B MOV

**B0MOV** SIOM,A

**B0BSET FSTART** ; 启动 SIO。

CHK\_END:

B0BTS0 **FSTART** ; 等待 SIO 结束。

RXDATA,A

**JMP** CHK END

**B0MOV** A,SIOB ;保存 SIOB 的数据到 RXDATA 中。

MOV

例: 主控模式下,下降沿触发时发送/接收数据。 MOV A,TXDATA

**B0MOV** SIOB,A

MOV A,#0FFH

**B0MOV** SIOR,A

A,#1000001B MOV

**B0MOV** SIOM.A

**BOBSET FSTART** ; 启动 SIO。

CHK\_END:

B0BTS0 **FSTART JMP** CHK END

**B0MOV** A,SIOB

MOV RXDATA,A ; 等待 SIO 结束。

; 设置 SIO 时钟。

:保存 SIOB 的数据到 RXDATA 中。

;把要传送的数据放到 SIOB 寄存器。

;初始化 SIOM,使能 SIO 功能。

;把要传送的数据放到 SIOB 寄存器。

;初始化 SIOM,使能 SIO 功能。

; 设置 SIO 时钟。

例: 主控模式下, 上升沿触发时接收数据。

MOV A.#0FFH

SIOR,A **B0MOV** 

MOV A.#10000010B

**B0MOV** SIOM.A

**BOBSET FSTART** 

; 启动 SIO。

CHK\_END:

B0BTS0 **FSTART** 

**JMP** CHK END

**B0MOV** A,SIOB

MOV RXDATA,A ;设置 SIO 时钟使其具有自动重装功能。

;初始化 SIOM,使能 SIO 功能。

: 等待 SIO 结束。

;保存 SIOB 的数据到 RXDATA 中。



例:主控模式下,下降沿触发时接收数据。

MOV A,#0FFH ; 设置 SIO 时钟。 BOMOV SIOR,A

MOV A,#10000000B ; 初始化 SIOM, 使能 SIO 功能。

BOMOV SIOM,A BOBSET FSTART : 启动 SIO

B0BSET FSTART ; 启动 SIO。 CHK END:

> B0BTS0 FSTART ; 等待 SIO 结束。 JMP CHK END

BOMOV A,SIOB ; 保存 SIOB 的数据到 RXDATA 中。

MOV RXDATA,A

▶ 例:从动模式下,上升沿触发时发送/接收数据。

MOV A,TXDATA ; 把要传送的数据放到 SIOB 寄存器。

BOMOV SIOB,A

MOV A,# 10000111B ; 初始化 SIOM,使能 SIO 功能。 BOMOV SIOM,A

B0BSET FSTART ; 启动 SIO。

CHK\_END: B0BTS0 FSTART ; 等待 SIO 结束。

> JMP CHK\_END B0MOV A,SIOB ; 保存 SIOB 的数据到 RXDATA 中。

MOV RXDATA,A

▶ 例:从动模式下,下降沿触发时发送/接收数据。

MOV A,TXDATA ; 把要传送的数据放到 SIOB 寄存器。

B0MOV SIOB,A MOV A,# 10000101B ; 初始化 SIOM,使能 SIO 功能。

BOMOV SIOM,A

BOBSET FSTART ; 启动 SIO。

CHK\_END:

BOBTSO FSTART ; 等待 SIO 结束。

JMP CHK\_END B0MOV A,SIOB ; 保存 SIOB 的数据到 RXDATA 中。

MOV RXDATA,A

》 例:从动模式下,上升沿触发时接收数据。

MOV A,# 10000110B ; 初始化 SIOM, 使能 SIO 功能。

BOMOV SIOM,A

BOBSET FSTART ; 启动 SIO。

CHK\_END:

BOBTSO FSTART ; 等待 SIO 结束。 JMP CHK\_END

BOMOV A,SIOB ; 保存 SIOB 的数据到 RXDATA 中。

MOV

**例:从动模式下,下降沿触发时接收数据。**MOV A,# 10000100B ; 初始化 SIOM,使能 SIO 功能。

B0MOV SIOM,A

B0BSET FSTART ; 启动 SIO。

RXDATA,A

CHK\_END: B0BTS0 FSTART ; 等待 SIO 结束。

JMP CHK\_END

BOMOV A,SIOB ; 保存 SIOB 的数据到 RXDATA 中。

MOV RXDATA,A



# 10 8 通道ADC

# 10.1 概述

模数转换(A/D)模块可以提供 8 个模拟输入通道, 高达 4096 阶的分辨率, 能将一个模拟信号转换成相应的 12 位数字信号。进行 AD 转换时, 首先要选择输入通道(AIN0~AIN7), 然后将 GCHS 和 ADS 位置"1", 并启动 AD 转换。当 AD 转换结束后, 系统会自动的把 EOC 置为"1", 并将转换结果存入寄存器 ADB 中。通过寄存器 ADR 的 ADLEN 位可以选择分辨率(8 位或 12 位)。



- 注:分辨率为8位时,转换时间需12个输入时钟;分辨率为12位时,转换时间需16个输入时钟。
- \* 注:模拟输入电压必须在 AVREFH 和 AVREFL 之间。
- ★ 注: SN8P2704A、SN8P2705A 和 SN8P2706A 中, AVREFL 内接 VSS。
- \* 注: AVREFH 的值必须在 AVDD 和 AVREFL+2.0V 之间。
- ☀ 注: AVREFL 的值必须在 AVSS 和 AVREFH-2.0V 之间。
- \* 注:ADC 设计时应注意:
- 1. ADC 的输入/输出引脚设置为输入模式。
- 2. 禁止 ADC 输入引脚的上拉电阻。
- 3. 在进入睡眠模式前禁止 ADC (ADENB = 0) 以省电。
- 4. 在省电模式下设置 P4CON 的有关位以避免额外功耗。
- 5. 允许 ADC (ADENB = 1) 后延迟 100us 等待 ADC 电路稳定。



# 10.2 ADM寄存器

| 0B1H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| ADM  | ADENB | ADS   | EOC   | GCHS  | -     | CHS2  | CHS1  | CHS0  |
| 读/写  | R/W   | R/W   | R/W   | R/W   | -     | R/W   | R/W   | R/W   |
| 复位后  | 0     | 0     | 0     | 0     | -     | 0     | 0     | 0     |

Bit 7 **ADENB**: ADC 使能位。

0 =禁止; 1 =使能。

Bit 6 ADS: ADC 启动控制位。

0 = 停止; 1 = 转换开始。

Bit 5 **EOC**: ADC 状态控制位。

0 = 转换过程中;

1 = 转换结束, ADS 复位。

Bit 4 GCHS: ADC 输入通道控制位。

0 = 禁止 AIN 通道; 1 = 允许 AIN 通道。

Bit[2:0] CHS[2:0]: ADC 输入通道选择位。

000 = AIN0; 001 = AIN1; 010 = AIN2; 011 = AIN3; 100 = AIN4; 101 = AIN5; 110 = AIN6; 111 = AIN7.

\* 注 若 ADENB = 1, 用户应设置 P4.n/AINn 为输入模式 且禁止上拉电阻 系统不会自动设置。若已经设置了 P4CON.n, P4.n/AINn 的数字功能(包括上拉电阻)被隔离。

# 10.3 ADR寄存器

| 0B3H | Bit 7  | Bit 6  | Bit 5 | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|--------|--------|-------|--------|-------|-------|-------|-------|
| ADR  | ADCKS2 | ADCKS1 | ADLEN | ADCKS0 | ADB3  | ADB2  | ADB1  | ADB0  |
| 读/写  | R/W    | R/W    | R/W   | R/W    | R     | R     | R     | R     |
| 复位后  | 0      | 0      | 0     | 0      | Х     | X     | X     | Х     |

Bit 7,6,4 ADCKS [2:0]: ADC 时钟源选择位。

| ADCKS2 | ADCKS1 | ADCKS0 | ADC 时钟源 |
|--------|--------|--------|---------|
| 0      | 0      | 0      | Fcpu/16 |
| 0      | 0      | 1      | Fcpu/8  |
| 0      | 1      | 0      | Fcpu/1  |
| 0      | 1      | 1      | Fcpu/2  |
| 1      | 0      | 0      | Fcpu/64 |
| 1      | 0      | 1      | Fcpu/32 |
| 1      | 1      | 0      | Fcpu/4  |
| 1      | 1      | 1      | 保留      |

Bit 5 **ADLEN**: ADC 分辨率选择位。

0 = 8位; 1 = 12位。

Bit [3:0] **ADB [3:0]**: ADC 数据缓存器。

ADB11~ADB4(8 位 ADC); ADB11~ADB0(12 位 ADC)。

😉 注:寄存器 ADR 的 ADB[3:0]的初始值是未知的。



# 10.4 ADB寄存器

| 0B2H | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|------|-------|-------|-------|-------|-------|-------|-------|-------|
| ADB  | ADB11 | ADB10 | ADB9  | ADB8  | ADB7  | ADB6  | ADB5  | ADB4  |
| 读/写  | R     | R     | R     | R     | R     | R     | R     | R     |
| 复位后  | Х     | Х     | Х     | X     | Х     | Х     | Х     | X     |

Bit[7:0] **ADB[7:0]**: ADC 12 位分辨率的高字节数据缓存器。

8 位数据缓存器 ADB 用来保存 AD 转换结果的高 8 位(bit4~bit11),转换结果的低 4 位则保存在 ADR 寄存器中。 ADB 为只读寄存器,在 8 位 ADC 模式下,AD 转换结果保存在寄存器 ADB 中;在 12 位模式下,则分别保存在寄存器 ADB 和 ADR 中。

AIN 的输入电压 v.s. ADB 的输出数据

| AIN n           | ADB11 | ADB10 | ADB9 | ADB8 | ADB7 | ADB6 | ADB5 | ADB4 | ADB3 | ADB2 | ADB1 | ADB0 |
|-----------------|-------|-------|------|------|------|------|------|------|------|------|------|------|
| 0/4096*VREFH    | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| 1/4096*VREFH    | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 1    |
|                 |       |       |      |      |      |      |      |      |      |      |      |      |
|                 |       |       |      |      |      |      |      |      |      |      |      |      |
|                 |       |       |      |      |      |      |      |      |      |      |      |      |
| 4094/4096*VREFH | 1     | 1     | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 0    |
| 4095/4096*VREFH | 1     | 1     | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    |

针对不同的应用,用户可能需要精度介于 8 位到 12 位之间的 AD 转换器。对于这种情况,可以通过对保存在 ADR 和 ADB 中的转换结果进行处理得到。首先,用户必须选择 12 位分辨率的模式,进行 AD 转换,然后在转换结果中去掉最低的几位得到需要的结果。如下表所示:

| ADC 分辨率                    |       |       |      |      | ADR  |      |      |      |      |      |      |      |
|----------------------------|-------|-------|------|------|------|------|------|------|------|------|------|------|
| ADC分辨率                     | ADB11 | ADB10 | ADB9 | ADB8 | ADB7 | ADB6 | ADB5 | ADB4 | ADB3 | ADB2 | ADB1 | ADB0 |
| 8-bit                      | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | Х    | Х    | Х    | Х    |
| 9-bit                      | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | Х    | Х    | Х    |
| 10-bit                     | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | Х    | Х    |
| 11-bit                     | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | Х    |
| 12-bit                     | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| <b>O</b> = 可选位, <b>x</b> = | 未使用的位 | Î     |      |      |      |      |      |      |      |      |      |      |

🛌 注:寄存器 ADB 各位的初始值是未知的。

# 10.5 P4CON寄存器

P4 口和 ADC 的输入口共享。同一时间只能设置 P4 口的一个引脚作为 ADC 的测量信号输入口(通过 ADM 寄存器来设置),其它引脚则作为普通 I/O 使用。具体应用中,当输入一个模拟信号到 CMOS 结构端口,尤其当模拟信号为 1/2 VDD时,将可能产生额外的漏电流。同样,当 P4 口外接多个模拟信号时,也会产生额外的漏电流。在睡眠模式下,上述漏电流会严重影响到系统的整体功耗。P4CON 为 P4 口的配置寄存器。将 P4CON[7:0]置"1",其对应的 P4 口将被设置为纯模拟信号输入口,从而避免上述漏电流的情况。

| 0AEH  | Bit 7                          | Bit 6 | Bit 5  | Bit 4  | Bit 3       | Bit 2  | Bit 1 | Bit 0 |
|-------|--------------------------------|-------|--------|--------|-------------|--------|-------|-------|
| P4CON | P4CON7 P4CON6 P4CON5 P4CON4 P4 |       | P4CON3 | P4CON2 | P4CON1      | P4CON0 |       |       |
| 读/写   | R/W                            | R/W   | R/W    | R/W    | R/W R/W R/W |        | R/W   | R/W   |
| 复位后   | 0                              | 0     | 0      | 0      | 0           | 0      | 0     | 0     |

Bit[4:0] **P4CON[7:0]:** P4.n 配置控制位。

0 = P4.n 作为模拟输入(ADC输入)引脚或者数字 I/O 引脚;

1 = P4.n 只能作为模拟输入引脚,不能作为数字 I/O 引脚。

\* 注:当 P4.n 为基本 I/O 而不是 ADC 通道时,P4CON.n 必须置"0", 否则 P4.n 的数字 I/O 信号会被隔离。



# 10.6 AD转换时间

12 位 AD 转换时间 = 1/(ADC clock /4)\*16 sec 8 位 AD 转换时间 = 1/(ADC clock /4) \*12 sec

Fcpu = 4MHz(高速时钟, Fosc = 16MHz, Fcpu = Fosc/4)

| Tepu — Hilliz (周速时) F 103C — Tolliniz, Tepu — To3C/47 |        |        |        |           |                              |  |  |  |  |  |
|-------------------------------------------------------|--------|--------|--------|-----------|------------------------------|--|--|--|--|--|
| ADLEN                                                 | ADCKS2 | ADCKS1 | ADCKS0 | ADC Clock | AD 转换时间                      |  |  |  |  |  |
|                                                       | 0      | 0      | 0      | Fcpu/16   | 1/ (4MHz/16/4) *12 = 192 us  |  |  |  |  |  |
| 0 (8-bit)                                             | 0      | 0      | 1      | Fcpu/8    | 1/ (4MHz/8/4) *12 = 96 us    |  |  |  |  |  |
| U (O-DIL)                                             | 0      | 1      | 0      | Fcpu      | 1/ (4MHz/4) *12 = 12 us      |  |  |  |  |  |
|                                                       | 0      | 1      | 1      | Fcpu/2    | 1/(4MHz/2/4) *12 = 24 us     |  |  |  |  |  |
| 0 (0 hit)                                             | 1      | 0      | 0      | Fcpu/64   | 1/ (4MHz/64/4) *12 = 768 us  |  |  |  |  |  |
|                                                       | 1      | 0      | 1      | Fcpu/32   | 1/ (4MHz/32/4) *12 = 384 us  |  |  |  |  |  |
| 0 (8-bit)                                             | 1      | 1      | 0      | Fcpu/4    | 1/(4MHz/4/4) *12 = 48 us     |  |  |  |  |  |
|                                                       | 1      | 1      | 1      | 保留        | 保留                           |  |  |  |  |  |
|                                                       | 0      | 0      | 0      | Fcpu/16   | 1/ (4MHz/16/4) *16 = 256 us  |  |  |  |  |  |
| 1 (12-bit)                                            | 0      | 0      | 1      | Fcpu/8    | 1/ (4MHz/8/4) *16 = 128 us   |  |  |  |  |  |
| 1 (12-011)                                            | 0      | 1      | 0      | Fcpu      | 1/ (4MHz/4) *16 = 16 us      |  |  |  |  |  |
|                                                       | 0      | 1      | 1      | Fcpu/2    | 1/ (4MHz/2/4) *16 = 32 us    |  |  |  |  |  |
|                                                       | 1      | 0      | 0      | Fcpu/64   | 1/ (4MHz/64/4) *16 = 1024 us |  |  |  |  |  |
| 1 (12-bit)                                            | 1      | 0      | 1      | Fcpu/32   | 1/ (4MHz/32/4) *16 = 512 us  |  |  |  |  |  |
|                                                       | 1      | 1      | 0      | Fcpu/4    | 1/ (4MHz/4/4) *16 = 64 us    |  |  |  |  |  |
|                                                       | 1      | 1      | 1      | 保留        | 系统保留                         |  |  |  |  |  |

# 10.7 ADC操作实例

例: 设置 AINO 为 12 位 ADC 输入并开启 AD 转换后进入省电模式。

ADC0:

**B0BSET FADENB** ;使能ADC电路。

**CALL** Delay100uS ; 延迟 100us 等待 ADC 电路开始转换。

MOV A, #0FEh

B0MOV ;禁止 P4.0 上拉电阻。 P4UR, A **B0BCLR** FP40M ;设置 P4.0 为输入模式。

MOV A, #01h B0MOV P4CON, A ;设置 P4.0 为模拟输入模式。

MOV A, #60H

**B0MOV** ADR, A ; 设置 12 位 ADC, ADC 时钟源 = Fosc。 MOV A,#90H

B0MOV ADM,A ;允许ADC并设置AINO输入。

**B0BSET** FADS ; 开始转换。

WADC0:

B0BTS1 **FEOC JMP** WADC0 **B0MOV** A,ADB **B0MOV** Adc\_Buf\_Hi, A

**B0MOV** A,ADR AND A, 0Fh

Power\_Down:

**B0BCLR FADENB** ; 关闭 AD 转换。

**B0BCLR** FCPUM1 **B0BSET** FCPUM0 ; 进入睡眠模式。

Adc\_Buf\_Low, A

**B0MOV** 



# 10.8 ADC电路



ADC 参考电压的高电平来自 VDD, VREFH 必须来自单片机的 VDD, 而不是其它 VDD。



ADC 参考电压的高电平来自外部电源, VREFH 和 VSS 之间的电容(47uF)有助于 VREFH 电压的稳定。



# **11** DAC

# 11.1 概述

单片机内置的数模转换(D/A)模块可以将 7 位数字信号转换成对应的 128 阶电流型模拟信号输出。当 DAENB 置"1"后,开启 DA 转换电路,DAM 寄存器中的 bit0~bit6 位通过梯形电阻网络被转换成相应的模拟信号并由 DAO 引脚输出。



#### DA 转换框图

为了得到合适的线性输出信号,通常在 DAO 和 GND 之间接一个负载电阻,下面给出了  $Vdd = 5V/R_L = 150ohm$  和  $Vdd = 3V/R_L = 150ohm$  时的曲线图。



带 RL 的 DAO 电路

DAC 输出电压(Vdd = 5V/3V)

- ▶ 注:
- 1、本 DA 转换器的设计不适合用作精确的 DC 电压输出,只适合于简单的音频应用。
- 2、为了得到最好的线性性能,负载电阻 RL 最大值为 150 ohm @5V 和 100 ohm @3V。

# 11.2 DAM寄存器

#### DAM 初始值 = 0000 0000

| P 47 11 1 |       |       |       |       |       |       |       |       |
|-----------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0B0H      | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| DAM       | DAENB | DAB6  | DAB5  | DAB4  | DAB3  | DAB2  | DAB1  | DAB0  |
| 读/写       | R/W   |
| 复位后       | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Bit 7 DAENB: DAC 控制位。

0 = 禁止;

1 = 允许。

Bit [6:0] **DAB [6:0]**:数字输入数据。



# 11.3 D/A转换说明

当 DAENB = 0 时, DAO 的输出不稳定,设置 DAENB = 1 后,DAO 的输出值就由 DAB 决定。

➢ 例: DAO 引脚输出 1/2 VDD。

MOV A, #00111111B

BOMOV DAM, A ; 设置 DAB 为 1/2 刻度。

BOBSET FDAENB ; 允许 DA 功能。

#### DAB 的数据和 DAO 的输出电压之间的关系如下:

| DAB6 | DAB5 | DAB4 | DAB3 | DAB2 | DAB1 | DAB0 | DAO        |
|------|------|------|------|------|------|------|------------|
| 0    | 0    | 0    | 0    | 0    | 0    | 0    | VSS        |
| 0    | 0    | 0    | 0    | 0    | 0    | 1    | Idac       |
| 0    | 0    | 0    | 0    | 0    | 1    | 0    | 2 * Idac   |
| 0    | 0    | 0    | 0    | 0    | 1    | 1    | 3 * Idac   |
|      |      |      |      |      |      |      |            |
|      |      |      |      |      |      |      |            |
|      |      |      |      |      |      |      |            |
| 1    | 1    | 1    | 1    | 1    | 1    | 0    | 126 * Idac |
| 1    | 1    | 1    | 1    | 1    | 1    | 1    | 127 * Idac |

\* 注: Idac = IFSO / (27-1) (IFSO 全程输出量)。



# NON:X 12 指令表

| 指令 | 指令格    | 式   | 说明                                                                          | С        | DC       | Z  | 周期    |
|----|--------|-----|-----------------------------------------------------------------------------|----------|----------|----|-------|
|    | MOV    | A,M | $A \leftarrow M$                                                            | -        | -        |    | 1     |
| М  | MOV    |     | M ← A                                                                       | -        | -        | -  | 1     |
| 0  | B0MOV  | A,M | $A \leftarrow M \text{ (bank 0)}$                                           | -        | -        |    | 1     |
| V  | B0MOV  |     | M (bank 0) ← A                                                              | -        | -        | -  | 1     |
| Е  | MOV    | A,I | A ← I                                                                       | -        | -        | -  | 1     |
|    | B0MOV  | M,I | M ← I, (M 仅适用于系统寄存器 R、Y、Z 、RBANK 和 PFLAG)                                   | -        | -        | -  | 1     |
|    | XCH    | A,M | $A \longleftrightarrow M$                                                   | -        | -        | -  | 1+N   |
|    | B0XCH  | A,M | A ←→M (bank 0)                                                              | -        | -        | -  | 1+N   |
|    | MOVC   |     | R, A ← ROM [Y,Z], R 存 ROM 数据的高字节,A 存 ROM 数据的低字节                             | -        | -        | -  | 2     |
|    | ADC    | A,M | A ← A + M + C, 如果产生进位则 C=1, 否则 C=0                                          |          | <b>V</b> |    | 1     |
| Α  | ADC    |     | M ← A + M + C, 如果产生进位则 C=1, 否则 C=0                                          |          | <b>√</b> |    | 1+N   |
| R  | ADD    |     | A ← A + M,如果产生进位则 C=1,否则 C=0                                                |          | <b>√</b> |    | 1     |
| 1  | ADD    |     | M ← A + M,如果产生进位则 C=1,否则 C=0                                                | 1        | 1        |    | 1+N   |
| Т  | B0ADD  |     | M(bank 0)← M(bank 0)+ A,如果产生进位则 C=1,否则 C=0                                  | 1        | 1        |    | 1+N   |
| Н  | ADD    |     | A ← A + I,如果产生进位则 C=1,否则 C=0                                                | 1        | √        | V  | 1     |
| М  | SBC    |     | A ← A - M - /C, 如果产生借位则 C=0,否则 C=1                                          | 1        | 1        |    | 1     |
| E  | SBC    |     | M ← A - M - /C, 如果产生借位则 C=0,否则 C=1                                          | 1        | 1        |    | 1+N   |
| Т  | SUB    |     | A ← A - M, 如果产生借位则 C=0,否则 C=1                                               | 1        | 1        |    | 1     |
| 1  | SUB    |     | M ← A - M, 如果产生借位则 C=0, 否则 C=1                                              | 1        | -        | V  | 1+N   |
| С  | SUB    |     | A ← A - I,如果产生借位则 C=0,否则 C=1                                                | 1        | √        | V  | 1     |
|    | MUL    |     | $R, A \leftarrow A * M$ ,乘积低字节存放到 ACC,高字节存放在系统寄存器 $R$ 中, $ZF$ 标志位受 ACC 内容影响 | -        | -        |    | 2     |
|    | AND    |     | A ← A 与 M                                                                   | -        | -        | V  | 1     |
| L  | AND    |     | M ← A 与 M                                                                   | -        | -        | V  | 1+N   |
| 0  | AND    |     | A ← A 与 I                                                                   | -        | -        | √  | 1     |
| G  | OR     |     | A ← A ∝ M                                                                   | -        | -        | √  | 1     |
| Ī  | OR     |     | M ← A 或 M                                                                   | -        | -        | √  | 1+N   |
| C  | OR     |     | A ← A 或 I                                                                   | -        | -        | V  | 1     |
|    | XOR    |     | A ← A 异或 M                                                                  | -        | -        | V  | 1     |
| 1  | XOR    |     | M ← A 昇或 M                                                                  | -        | -        | √  | 1+N   |
|    | XOR    |     | A←A异或I                                                                      | -        | -        | 1  | 1     |
|    | SWAP   | M   | A (b3~b0, b7~b4) ←M (b7~b4, b3~b0)                                          | -        | -        | ·  | 1     |
| Р  | SWAPM  | M   | M (b3~b0, b7~b4) ← M (b7~b4, b3~b0)                                         | -        | -        | 1_ | 1+N   |
| R  | RRC    | M   | A ← M 带进位右移                                                                 | V        | -        | -  | 1     |
| 0  | RRCM   | M   | M ← M 带进位右移                                                                 | 1        | -        | -  | 1+N   |
| C  | RLC    | M   | A ← M 带进位左移                                                                 | ·<br>√   | -        | -  | 1     |
| E  | RLCM   | M   | M ← M 带进位左移                                                                 | <b>√</b> | -        |    | 1+N   |
| s  | CLR    | M   | M ← 0                                                                       | -        | -        | -  | 1     |
| s  | BCLR   |     | M.b ← 0                                                                     | -        | -        | -  | 1+N   |
|    | BSET   |     | M.b ← 1                                                                     | -        | -        | -  | 1+N   |
|    | B0BCLR |     | $M(bank 0).b \leftarrow 0$                                                  | -        | -        | -  | 1+N   |
| L  | B0BSET |     | M(bank 0).b ← 1                                                             | -        |          | -  | 1+N   |
|    | CMPRS  | A,I | 比较,如果相等则跳过下一条指令 C 与 ZF 标志位可能受影响                                             |          | -        |    | 1 + S |
| В  | CMPRS  |     | 比较,如果相等则跳过下一条指令C与ZF标志位可能受影响                                                 | 1        | -        | 1  | 1 + S |
| R  | INCS   | М   | A ← M + 1, 如果 A = 0, 则跳过下一条指令                                               | -        | -        | -  | 1+ S  |
| Α  | INCMS  | М   | M ← M + 1, 如果 M = 0,则跳过下一条指令                                                | -        | -        | -  | 1+N+S |
| Ν  | DECS   | М   | A ← M - 1, 如果 A = 0, 则跳过下一条指令                                               | -        | -        | -  | 1+ S  |
| С  | DECMS  | М   | M ← M - 1, 如果 M = 0, 则跳过下一条指令                                               | -        | -        | -  | 1+N+S |
| Н  | BTS0   | M.b | 如果 $M.b = 0$ ,则跳过下一条指令                                                      | -        | -        | -  | 1 + S |
|    | BTS1   | M.b | 如果 M.b = 1,则跳过下一条指令                                                         | -        | -        | -  | 1 + S |
|    | B0BTS0 | M.b | 如果 <b>M(bank 0).b</b> = <b>0</b> ,则跳过下一条指令                                  | -        | -        | -  | 1 + S |
|    | B0BTS1 | M.b | 如果 M(bank 0).b = 1,则跳过下一条指令                                                 | -        | -        | -  | 1 + S |
|    | JMP    | d   | 跳转指令,PC15/14 ← RomPages1/0,PC13~PC0 ← d                                     | -        | -        | -  | 2     |
|    | CALL   | d   | 子程序调用指令,Stack ← PC15~PC0,PC15/14 ← RomPages1/0,PC13~PC0 ← d                 | -        | -        | -  | 2     |
| M  | RET    |     | 子程序跳出指令,PC ← Stack                                                          | -        | -        | -  | 2     |
| 1  | RETI   |     | 中断处理程序跳出指令,PC ← Stack,使能全局中断控制位                                             | -        | -        | -  | 2     |
| S  | PUSH   |     | 进栈指令,保存 PFLAG 等工作寄存器                                                        |          | -        | _  | 1     |
| C  | POP    |     | 出栈指令,恢复 PFLAG 等工作寄存器                                                        | -<br>√   |          | V  | 1     |
|    | NOP    |     | 空指令,无特别意义                                                                   | -        | -        | -  | 1     |
|    |        |     | LINY, AND MAKE                                                              | 1        |          |    | •     |

注: 1. "M"是系统寄存器或 RAM, 若是系统寄存器,则 N = 0, 否则 N = 1。

<sup>2.</sup> 若满足跳转条件, S = 1, 否则 S = 0。



# 13 电气特性

# 13.1 极限参数

(All of the voltages referenced to Vss)

Operating ambient temperature (Topr)

SN8P2704AK, SN8P2704AS, SN8P2705AP, SN8P2705AS, SN8P2706AP, SN8P2707AQ

# 13.2 电气特性

(All of voltages referenced to Vss, Vdd = 5.0V, fosc = 4 MHz,fcpu=1MHZ, ambient temperature is 25 ℃ unless otherwise note.)

| PARAMETER                      | SYM.               |                                         | nz,rcpu=rwnz, ambient te<br>RIPTION | MIN.     | TYP.        | MAX.     | UNIT                |
|--------------------------------|--------------------|-----------------------------------------|-------------------------------------|----------|-------------|----------|---------------------|
| · / us will i bit              |                    | 1                                       |                                     |          | <del></del> | 1717-771 |                     |
| Operating voltage              | Vdd                | Normal mode, Vpp = Vdd                  | 2.4                                 | 5.0      | 5.5         | V        |                     |
| RAM Data Retention voltage     | Vdr                |                                         |                                     | 1.5      | -           | -        | V                   |
| Vdd rise rate                  | Vpor               | Vdd rise rate to ensure inte            | ernal power-on reset                | 0.05     | -           | -        | V/ms                |
| Input Low Voltage              | ViL1               | All input ports                         |                                     | Vss      | -           | 0.3Vdd   | V                   |
| input Low voltage              | ViL2               | Reset pin                               |                                     | Vss      | -           | 0.2Vdd   | V                   |
| Input High Voltage             | ViH1               | All input ports                         |                                     | 0.7Vdd   | -           | Vdd      | V                   |
| input rlight voltage           | ViH2               | Reset pin                               |                                     | 0.9Vdd   | -           | Vdd      | V                   |
| Reset pin leakage current      | llekg              | Vin = Vdd                               |                                     | -        | -           | 2        | uA                  |
| I/O port pull-up resistor      | Rup                | Vin = Vss , Vdd = 3V                    |                                     | 100      | 200         | 300      | ΚΩ                  |
|                                | Rup                | Vin = Vss , Vdd = 5V                    |                                     | 50       | 100         | 150      | ΚΩ                  |
| I/O port input leakage current | llekg              | Pull-up resistor disable, Vi            | n = Vdd                             | -        | -           | 2        | uA                  |
| I/O output source current      | loH                | Vop = Vdd - 0.5V                        |                                     | 8        | 12          | -        | mA                  |
| sink current                   | loL                | Vop = Vss + 0.5V                        |                                     | 8        | 15          | -        | mA                  |
| INTn trigger pulse width       | Tint0              | INT0 ~ INT2 interrupt requ              | est pulse width                     | 2/fcpu   | -           | -        | Cycle               |
| AVREFH input voltage           | Varfh              | Vdd = 5.0V                              |                                     | Varfl+2V | -           | Vdd      | V                   |
| AVREFL input voltage           | Varfl              | Vdd = 5.0V                              |                                     | Vss      | -           | Varfh-2V | V                   |
| AIN0 ~ AIN7 input voltage      | Vani               | Vdd = 5.0V                              |                                     | Varfl    | -           | Varfh    | V                   |
|                                |                    | normal Mode                             | Vdd= 5V 4MHz                        | -        | 3           | 6        | mA                  |
|                                | ldd1               | (No loading,<br>Fcpu = Fosc/4)          | Vdd= 3V 4MHz                        | -        | 1.5         | 3        | mA                  |
|                                | ldd2               | Slow Mode                               | Vdd= 5V ILRC 32KHz                  | -        | 80          | 160      | uA                  |
| Supply Current                 |                    | (Internal low RC, Stop high clock)      | Vdd= 3V ILRC 16KHz                  | -        | 15          | 30       | uA                  |
| (ADC Disable)                  | Idd3               | Sleep Mode                              | Vdd= 5V                             | -        | 1           | 2        | uA                  |
|                                |                    |                                         | Vdd= 3V                             | -        | 0.5         | 2        | uA                  |
|                                |                    | Green Mode                              | Vdd= 5V 4MHz                        | -        | 0.6         | 1.2      | mA                  |
|                                | ldd4               | (No loading,<br>Fcpu = Fosc/4, Watchdog | Vdd= 3V 4MHz                        | -        | 0.2         | 0.4      | mA                  |
|                                |                    |                                         |                                     | -        | 20          | 40       | uA                  |
|                                |                    | Disable)                                | Vdd= 3V ILRC 16Khz                  | -        | 5           | 10       | uA                  |
| LVD Detect Voltage             | Vdet               | Low voltage detect level                |                                     | 1.5      | 1.8         | 2.2      | V                   |
| DAC Full-scale Output Current  | I <sub>FSO</sub>   | Vdd=5.0V                                |                                     | 8        | 14          | 21       | mA                  |
|                                |                    | Vdd=3.0V                                | 5                                   | 11       | 18          | mA       |                     |
| DAC Loading Resistance         | $R_L$              |                                         | Vdd=5.0V                            |          |             | 150      | Ω                   |
|                                |                    | Vdd=3.0V                                |                                     | -        | -           | 100      | Ω                   |
| DAC DNL                        | DAC <sub>DNL</sub> | DAC Differential NonLinea               | -                                   | -        | ±1*         | -        | LSB                 |
| DAC INL                        | DAC <sub>INL</sub> | DAC Integral NonLinearity               | ·                                   | -        | ±3*         | -        | LSB                 |
| ADC current consumption        | I <sub>ADC</sub>   | Vdd=5.0V                                | -                                   | 0.6*     | -           | mA       |                     |
| <u>'</u>                       |                    | Vdd=3.0V                                |                                     | -        | 0.4*        | -        | mA                  |
| ADC enable time                | Tast               | Ready to start convert after            | er set ADENB = "1"                  | 100      | -           | -        | uS                  |
| ADC Clock Frequency            | FADCLK             |                                         |                                     |          |             | 8M       | Hz                  |
| ADC Clock Frequency            |                    | VDD=3.0V                                |                                     | -        |             | 5M       | Hz                  |
| ADC Conversion Cycle Time      | F <sub>ADCYL</sub> | VDD=2.4V~5.5V                           |                                     |          |             |          | 1/F <sub>ADCL</sub> |
| ADC Sampling Rate              | F <sub>ADSMP</sub> | VDD=5.0V                                |                                     | 64       |             | 125      | K/sec               |
| (Set FADS=1 Frequency)         | · ADOINIA          | VDD=3.0V                                |                                     |          | †           | 80       | K/sec               |
| Differential Nonlinearity      | DNL                | VDD=5.0V , AVREFH=                      | 3.2V, F <sub>ADSMP</sub> =7.8K      | ±1       | ±2          | ±16      | LSB                 |
| Into and Nouline suit.         | INL                | VDD=5.0V , AVREFH=                      | 3.2V. FADSMR =7.8K                  | ±2       | ±4          | ±16      | LSB                 |
| Integral Nonlinearity          |                    | 100-0.01 , / (TRE: 11-)                 | OIL 1, 1 ADSIVIF 11011              |          |             | ± 10     |                     |

<sup>\*</sup>These parameters are for design reference, not tested.



# 13.3 特性曲线图

The Graphs in this section are for design guidance, not tested or guaranteed. In some graphs, the data presented are outside specified operating range. This is for information only and devices are guaranteed to operate properly only within the specified range.

### **SN8P2708A**



Working Voltage vs. Frequency (Noise Filter Disable、25℃)



# 14 应用注意事项

## 14.1 开发工具

### 14.1.1 在线仿真器 (ICE)

- S8KD-2 ICE: S8KD-2 ICE 仅供 SN8P1XXX 系列产品的仿真,不支持 SN8P2700A 系列的仿真。
- **SN8ICE 2K:** 可以仿真 **SN8P2700A** 系列的全部功能。

### 14.1.2 一次性编程烧录器(OTP烧录器)

● MP WriterIII: 支持 SN8P2700A 的联机烧录,也支持大批量的脱机烧录。

### 14.1.3 集成开发环境(IDE)

SONiX 8 位单片机的集成开发环境包括编译器、ICE 调试器和 OTP 的烧录软件。

- **S8KD-2 ICE:** SN8IDE\_199Z01 或更新的版本,不支持 SN8P2000 系列的编译。
- **SN8ICE 2K:** M2IDE\_V115 或更新的版本。
- MP WriterIII: M2IDE\_V115 或更新的版本。



## 14.2 SN8P2700A的指令限制

### 14.2.1 B0MOV M,I

★ 注: I 不能是 E6H 和 E7H。

在查表时会经常用到这条指令以获得 ROM 表的地址,用户在分配 ROM 表的地址时可以通过 ORG 的指示以避开 E6H和 E7H。

》 例: 通过 ORG 设置表格的开始地址。

ORG 0100H ; 设置 ROM 表的地址从 0100H 开始。

Table:

DW 9876H

. . .

### 14.2.2 B0XCH A, M

¥ 注:M 的地址不能是系统寄存器的地址(80H~0FFH)。

▶ 例:在中断服务程序中保存 PFLAG。

错误的程序!

BOXCH A, PFLAG ; PFLAG 是系统寄存器,不能使用指令 BOXCH A, M。

B0MOV PFLAGBUF, A

正确的程序!

B0MOV A, PFLAG ; 用指令 B0MOV 替换 B0XCH。

BOMOV PFLAGBUF, A ; PFLAGBUF 不是系统寄存器。

➢ 例:保存 ACC。

ACCBUF DS 1 ; 定义 ACCBUF 为 ACC 的缓存器。

ORG 0

ORG 10H

BOXCH A, ACCBUF ; ACCBUF 不是系统寄存器。



# 14.3 ROM地址 8 处(中断向量)的有效指令

注: 在 0008H 处的有效指令只能是 JMP 或 NOP。

▶ 例:SN8P2700A的两个正确的中断向量的示例程序。

.CODE

ORG 8H ;中断服务程序。

NOP ; 0008H 处的第一条指令。

...

RETI ; 中断返回。

...

.CODE

ORG 8H

JMP MY\_IRQ ; 0008H, 跳转到中断服务程序。

ORG 10H START:

; 0010H,用户程序开始。

; 用户程序。

.

JMP START ; 用户程序结束。

MY\_IRQ: ;中断服务程序开始。

•••

RETI ;中断返回。

• • •

ENDP ;程序结束。



# 14.4 SN8P1708 升级为SN8P2708A

### 14.4.1 性能比较表

| 项目                           | SN8P270xA                    | SN8P170x                   |  |
|------------------------------|------------------------------|----------------------------|--|
| AC 抗干扰性                      | 很好(在 VDD 和 VSS 之间添加一个        | 一般                         |  |
|                              | <b>47uf</b> 的旁路电容)           | , , ,                      |  |
| 运算速度(16MHz 晶振)               | 高达 16MIPS                    | 4MIPS                      |  |
|                              | PWM 分辨率: 8/6/5/4 位           |                            |  |
| 高速 PWM                       | High Clock = 16MHz           | PWM 分辨率: 只 8 位             |  |
| ,                            | 8 位分辨率时高达 31.25K             | 在 16MHz 等于 7.8125K         |  |
| (ODINI TIMERI EL LIO TIRRIW. | 4 位分辨率时高达 500K               |                            |  |
| 48PIN 封装时最大 I/O 引脚数          | 36                           | 33                         |  |
| (SN8P2708A 与 SN8P1708)       |                              |                            |  |
| 可编程漏极开路输出引脚                  | P1.0 / P1.1 / P5.2 (SO)      | -                          |  |
| B0MOV M, I                   | I 的值不能为 0E6 或 0E7            | 无限制                        |  |
| B0XCH A, M                   | M 的地址不能为 80h~FFh             | 无限制                        |  |
| ROM 中地址 8 处的有效指令             | JMP 或 NOP                    | 无限制                        |  |
| ADC 中断                       | 有                            | -                          |  |
| ADC VREFL(参考低电压)             | 有                            | -                          |  |
| ADC 时钟频率                     | 七种设置(通过 ADCKS [2:0]设置)       | 两种设置(通过 ADCKS 设置)          |  |
| 绿色模式                         | 有                            | -                          |  |
| 施密特触发输入引脚                    | 所有的输入引脚(P4口除外)               | P0、RST、XIN                 |  |
| P0                           | 输入/输出引脚                      | 输入引脚                       |  |
| P0.0 中断沿触发                   | 下降沿/上升沿/双向沿                  | 下降沿                        |  |
| P0.1/P0.2 中断沿触发              | 下降沿                          | 下降沿                        |  |
| P0 和 P1 的唤醒功能                | 电平变化触发(下降或上升)                | 低电平                        |  |
| 唤醒时间                         | 1/Fosc*4096 (sec) +振荡器稳定时间   | 1/Fosc*2048 (sec) +振荡器稳定时间 |  |
| SIO 双缓存器                     | 有                            | -                          |  |
| SIOM 寄存器的 SEDGE 位的定义         | 参照 SIO 和使用                   | 注意事项章节                     |  |
| TC0C/TC1C/TC0R/TC1R 的有效范围    | 00H~ 0FFH                    | 00H ~0FFH                  |  |
| 看门狗计数器时钟源                    | 内部低速 RC 时钟                   | 外部高速时钟                     |  |
| 看门狗清零                        | MOV A, #5AH<br>B0MOV WDTR, A | B0BSET FWDRST              |  |
| LVD                          | 1.8V 常开                      | 2.4V ON/OFF                |  |
| 待机电流                         | 1uA 5V                       | 9uA 5V(LVD 美闭)             |  |

\* 注:

1、本手册中提到的电平变化触发是指下降沿触发或上升沿触发;

2、为避免系统无法进入睡眠模式及降低待机电流,建议用户编程时使能 P1 口未定义引脚相应位的上拉电阻。

SN8P2704A: 设置 P1UR 的 bit5 $\sim$ bit7 为 "1" (P1.5 $\sim$ P1.7); SN8P2705A: 设置 P1UR 的 bit6 $\sim$ bit7 为 "1" (P1.6 $\sim$ P1.7); SN8P2706A: 设置 P1UR 的 bit6 $\sim$ bit7 为 "1" (P1.6 $\sim$ P1.7); SN8P2707A: 设置 P1UR 的 bit6 $\sim$ bit7 为 "1" (P1.6 $\sim$ P1.7)。



### 14.4.2 配置编译选项

### 编译选项的比较表

| SN8P        | 170X      | SN8P270XA    |                    |  |
|-------------|-----------|--------------|--------------------|--|
| Code (      | Option    | Co           | de Option          |  |
|             | RC        |              | Ext_RC             |  |
| High_Clk    | 12M_X'tal | High_Clk     | 12M_X'tal          |  |
|             | 4M_X'tal  |              | 4M_X'tal           |  |
| High_Clk/2  | Enable    | Fcpu         | Fosc/1~ Fosc/128   |  |
| TilgII_CINZ | Disable   | Рсри         | FUSC/ 1~ FUSC/ 120 |  |
| Security    | Enable    | Security     | Enable             |  |
| Security    | Disable   | Security     | Disable            |  |
| Watch_Dog   | Enable    |              | Enable             |  |
| watch_bog   | Disable   | Watah Dag    | Disable            |  |
| LVD         | Enable    | Watch_Dog    | Alwaye ON          |  |
| LVD         | Disable   |              | Always_ON          |  |
| OSG         | Enable    | Noise_Filter | Enable             |  |
| 030         | Disable   | Noise_Filler | Disable            |  |

### 编译选项的修改表

| SN8F         | P1708   | SN8P2708A     |            |  |  |
|--------------|---------|---------------|------------|--|--|
| Code         | Option  | Code Option   |            |  |  |
| High_Clk/2   | Enable  | Fcpu          | High_Clk/8 |  |  |
| Tilgit_Clk/2 | Disable | Гсри          | HighClk/4  |  |  |
|              | Enable  |               | Always_ON  |  |  |
| Watch_Dog    | Lilable | Watch_Dog     | Enable     |  |  |
|              | Disable |               | Disable    |  |  |
| LVD          | Enable  |               | Enable     |  |  |
| LVD          | Disable | Noise Filter  | Disable    |  |  |
| OSG          | Enable  | INDISE_FIILEI | Enable     |  |  |
| 030          | Disable |               | Disable    |  |  |

- \* 注 1: SN8P270XA 的指令周期为 1 个时钟周期,Fcpu = Fosc/1 ~ Fosc/128;但是 SN8P1708 的 Fcpu 固定为 Fosc/4。若在 SN8P170X 升级为 SN8P270XA 时 Fosc 没有改变,请按照以下的方式配置 Fcpu 的编译选项:
  - SN8P170X HighClk/2 = Enable
- → SN8P270XA Fcpu = Fosc/8
- SN8P170X HighClk/2 = Disable SN8P270XA Fcpu = Fosc/4
- \* 注 2:在开发 SN8P270XA 时,如果设置 Watch\_Dog 为 "Always\_ON",则看门狗定时器始终处于使能状态。



## 14.5 SIO的移植

### 14.5.1 SN8P270XA SIO时序图



### 14.5.2 SN8P170X SIO时序图





### 14.5.3 SIOM配置表

| SIO 模式                | SI    | SN8P1708 |      |       | SN8P2708A |      |  |
|-----------------------|-------|----------|------|-------|-----------|------|--|
| 510 侯式                | SCKMD | SEDGE    | TXRX | SCKMD | SEDGE     | TXRX |  |
| 主控模式下,上升沿双向发送/接收数据    | 0     | 1        | 1    | 0     | 0         | 1    |  |
| 主控模式下,下降沿双向发送/接收数据    | 0     | 0        | 1    | 0     | 1         | 1    |  |
| 主控模式下,单向接收数据并在下降沿发送数据 | 0     | 1        | 0    | 0     | 1         | 0    |  |
| 主控模式下,单向接收数据并在上升沿发送数据 | 0     | 0        | 0    | 0     | 0         | 0    |  |
| 从动模式下,上升沿双向发送/接收数据    | 1     | 1        | 1    | 1     | 0         | 1    |  |
| 从动模式下,下降沿双向发送/接收数据    | 1     | 0        | 1    | 1     | 1         | 1    |  |
| 从动模式下,单向接收数据并在下降沿发送数据 | 1     | 1        | 0    | 1     | 1         | 0    |  |
| 从动模式下,单向接收数据并在上升沿发送数据 | 1     | 0        | 0    | 1     | 0         | 0    |  |

### 》 例: 主控模式下,上升沿发送/接收数据。

### SN8P1708

MOV A,TXDATA ; 把要传送的数据放到SIOB寄存器。

BOMOV SIOB,A ; 设置SIO时钟具有自动装载功能。

BOMOV SIOR,A

MOV A,**#10000011B** ; 初始化SIOM并使能SIO,上升沿触发。

B0MOV SIOM,A B0BSET FSTART ; 开始 SIO 传输。

CHK\_END:

BOBTSO FSTART ; 等待 SIO 传输结束。

JMP CHK\_END B0MOV A,SIOB : 把SIOB中数据保存到RXDATA。

MOV RXDATA,A

#### SN8P2708A

MOV A,TXDATA ; 把要传送的数据放到 SIOB 寄存器。

BOMOV SIOB,A MOV A,#0FFH ; 设置 SIO 时钟具有自动装载功能。

BOMOV SIOR,A

MOV A,**#10000001B** ; 初始化 SIOM 并使能 SIO, 上升沿触发。

BOMOV SIOM,A BOBSET FSTART ; 开始 SIO 传输。

CHK\_END:

B0BTS0 FSTART ; 等待 SIO 传输结束。

JMP CHK\_END B0MOV A,SIOB ; 把SIOB中数据保存到RXDATA。

MOV RXDATA,A



# 15 OTP烧录信息

# 15.1 烧录转接板信息



注 1: JP1 连接 MP 烧录转接板,JP3 连接 OTP MCU。

注 2: JP2 连接外部烧录转接板。当 OTP MCU 的 PIN 超过 48PIN,或者烧录 Dice MCU 时,请采用外部烧录转接板,连接到 JP2 进行烧录。

下面两个图演示了如何焊接烧录转接板。







图 3



- \* 注:
- 1、印有 IC 型号的这一面为转接板的正面。
- 2、180 度的母座必须焊接在 MP 转接板的背面。请参考图 2 和图 3。



图 4 MP 转接板 (连接到 JP1&JP3)

| JP3(连接 48-pin text tool) |    |    |       |  |  |  |  |
|--------------------------|----|----|-------|--|--|--|--|
| DIP 1                    | 1  | 48 | DIP48 |  |  |  |  |
| DIP 2                    | 2  | 47 | DIP47 |  |  |  |  |
| DIP 3                    | 3  | 46 | DIP46 |  |  |  |  |
| DIP 4                    | 4  | 45 | DIP45 |  |  |  |  |
| DIP 5                    | 5  | 44 | DIP44 |  |  |  |  |
| DIP 6                    | 6  | 43 | DIP43 |  |  |  |  |
| DIP 7                    | 7  | 42 | DIP42 |  |  |  |  |
| DIP 8                    | 8  | 41 | DIP41 |  |  |  |  |
| DIP 9                    | 9  | 40 | DIP40 |  |  |  |  |
| DIP10                    | 10 | 39 | DIP39 |  |  |  |  |
| DIP11                    | 11 | 38 | DIP38 |  |  |  |  |
| DIP12                    | 12 | 37 | DIP37 |  |  |  |  |
| DIP13                    | 13 | 36 | DIP36 |  |  |  |  |
| DIP14                    | 14 | 35 | DIP35 |  |  |  |  |
| DIP15                    | 15 | 34 | DIP34 |  |  |  |  |
| DIP16                    | 16 | 33 | DIP33 |  |  |  |  |
| DIP17                    | 17 | 32 | DIP32 |  |  |  |  |
| DIP18                    | 18 | 31 | DIP31 |  |  |  |  |
| DIP19                    | 19 | 30 | DIP30 |  |  |  |  |
| DIP20                    | 20 | 29 | DIP29 |  |  |  |  |
| DIP21                    | 21 | 28 | DIP28 |  |  |  |  |
| DIP22                    | 22 | 27 | DIP27 |  |  |  |  |
| DIP23                    | 23 | 26 | DIP26 |  |  |  |  |
| DIP24                    | 24 | 25 | DIP25 |  |  |  |  |

| JP1/JP2    |    |    |             |  |  |  |  |  |
|------------|----|----|-------------|--|--|--|--|--|
| VDD        | 1  | 2  | VSS         |  |  |  |  |  |
| CLK/PGCLK  | 3  | 4  | CE          |  |  |  |  |  |
| PGM/OTPCLK | 5  | 6  | OE/ShiftDat |  |  |  |  |  |
| D1         | 7  | 8  | D0          |  |  |  |  |  |
| D3         | 9  | 10 | D2          |  |  |  |  |  |
| D5         | 11 | 12 | D4          |  |  |  |  |  |
| D7         | 13 | 14 | D6          |  |  |  |  |  |
| VDD        | 15 | 16 | VPP         |  |  |  |  |  |
| HLS        | 17 | 18 | RST         |  |  |  |  |  |
| -          | 19 | 20 | ALSB/PDB    |  |  |  |  |  |

JP1 连接 MP 烧录转接板 JP2 连接外部转接板



### 15.1.1 SN8P2700A系列的烧录引脚信息

| SN8P2700A 系列的 OTP 烧录引脚信息 |            |         |        |          |                |         |         |           |            |         |  |
|--------------------------|------------|---------|--------|----------|----------------|---------|---------|-----------|------------|---------|--|
| 单片机                      | <b>上名称</b> | SN8F    | 2704A  | K/S/X    | SN8P2705AP/S/Q |         |         | SN8I      | SN8P2706AP |         |  |
| MPIII V                  | Vriter     |         |        |          | OTP IC         | : / JP3 | 引脚配置    |           |            |         |  |
| JP1/JP2 Pin              | JP1/JP2    | IC Pin  | IC Pin | JP3 Pin  | IC Pin         | IC Pin  | JP3 Pin | IC Pin    | IC Pin     | JP3 Pin |  |
| Number                   | Pin Name   | Number  | Name   | Number   | Number         | Name    | Number  | Number    | Name       | Number  |  |
| 1                        | VDD        | 3,14,24 | VDD    | 13,24,34 | 4,26           | VDD     | 12,34   | 4,22,36   | VDD        | 8,26,40 |  |
| 2                        | GND        | 7,21    | VSS    | 17,31    | 1,16           | VSS     | 9,24    | 12,33     | VSS        | 16,37   |  |
| 3                        | CLK        | 20      | P5.0   | 30       | 32             | P5.0    | 40      | 31        | P5.0       | 35      |  |
| 4                        | CE         | -       | -      | -        | -              | -       | -       | -         | -          | -       |  |
| 5                        | PGM        | 6       | P1.0   | 16       | 14             | P1.0    | 22      | 7         | P1.0       | 11      |  |
| 6                        | OE         | 19      | P5.1   | 29       | 31             | P5.1    | 39      | 30        | P5.1       | 34      |  |
| 7                        | D1         | -       | -      | -        | -              | -       | -       | -         | -          | -       |  |
| 8                        | D0         | -       | -      | -        | -              | -       | -       | -         | -          | -       |  |
| 9                        | D3         | -       | -      | -        |                | -       | -       | -         | -          | -       |  |
| 10                       | D2         | -       | -      | 1        | 1              | -       | -       | ı         | -          | -       |  |
| 11                       | D5         | -       | -      | 1        | 1              | -       | -       | ı         | -          | -       |  |
| 12                       | D4         | -       | -      | -        | -              | -       | -       | -         | -          | -       |  |
| 13                       | D7         | -       | -      | -        | -              | -       | -       | -         | -          | -       |  |
| 14                       | D6         | -       | -      | -        | -              | -       | -       | -         | -          | -       |  |
| 15                       | VDD        | 3,14,24 | VDD    | 13,24,34 | 4,26           | VDD     | 12,34   | 4, 22, 36 | VDD        | 8,26,40 |  |
| 16                       | VPP        | 28      | RST    | 38       | 8              | RST     | 16      | 40        | RST        | 44      |  |
| 17                       | HLS        | -       | -      | -        | -              | -       | -       | -         | -          | -       |  |
| 18                       | RST        | -       | -      | -        | -              | -       | -       | -         | -          | -       |  |
| 19                       | -          | -       | -      | -        | -              | -       | -       | -         | -          | -       |  |
| 20                       | ALSB/PDB   | 5       | P1.1   | 15       | 13             | P1.1    | 21      | 6         | P1.1       | 10      |  |

| SN8P2700A 系列的 OTP 烧录引脚信息 |             |        |         |          |              |        |            |  |
|--------------------------|-------------|--------|---------|----------|--------------|--------|------------|--|
| 单片机                      | <b>L</b> 名称 | SN     | 18P2707 | AQ       | SN8P2708AX/Q |        |            |  |
| MPIII V                  | Vriter      |        |         | OTP IC / | JP3 引脚配置     | į.     |            |  |
| JP1/JP2 Pin              | JP1/JP2     | IC Pin | IC Pin  | JP3 Pin  | IC Pin       | IC Pin | JP3 Pin    |  |
| Number                   | Pin Name    | Number | Name    | Number   | Number       | Name   | Number     |  |
| 1                        | VDD         | 1,9,28 | VDD     | 3,11,30  | 8,16,35,36   | VDD    | 8,16,35,36 |  |
| 2                        | GND         | 17,42  | VSS     | 19,44    | 5,25         | VSS    | 5,25       |  |
| 3                        | CLK         | 37     | P5.0    | 39       | 47           | P5.0   | 47         |  |
| 4                        | CE          | -      | -       | -        | -            | -      | -          |  |
| 5                        | PGM         | 12     | P1.0    | 14       | 20           | P1.0   | 20         |  |
| 6                        | OE          | 36     | P5.1    | 38       | 46           | P5.1   | 46         |  |
| 7                        | D1          | -      | -       | -        | -            | -      | -          |  |
| 8                        | D0          | -      | -       | -        | -            | -      | -          |  |
| 9                        | D3          | -      | -       | -        | -            | -      | -          |  |
| 10                       | D2          | -      | -       | -        | -            | -      | -          |  |
| 11                       | D5          | -      | -       | -        | -            | -      | -          |  |
| 12                       | D4          | -      | -       | -        | -            | -      | -          |  |
| 13                       | D7          | -      | -       | -        | -            | -      | -          |  |
| 14                       | D6          | -      | -       | -        | -            | -      | -          |  |
| 15                       | VDD         | 1,9,28 | VDD     | 3,11,30  | 8,16,35,36   | VDD    | 8,16,35,36 |  |
| 16                       | VPP         | 5      | RST     | 7        | 12           | RST    | 12         |  |
| 17                       | HLS         | -      | -       | -        | -            | -      | -          |  |
| 18                       | RST         | -      | -       | -        | -            | -      | -          |  |
| 19                       | -           | -      | -       | -        | -            | -      | -          |  |
| 20                       | ALSB/PDB    | 11     | P1.1    | 13       | 19           | P1.1   | 19         |  |



# 16 封装

## **16.1 SK-DIP28 PIN**



| Symbols | MIN.  | NOR.      | MAX.  |
|---------|-------|-----------|-------|
| Α       | -     | -         | 0.210 |
| A1      | 0.015 | -         | -     |
| A2      | 0.114 | 0.130     | 0.135 |
| D       | 1.390 | 1.390     | 1.400 |
| E       |       | 0.310BSC. |       |
| E1      | 0.283 | 0.288     | 0.293 |
| L       | 0.115 | 0.130     | 0.150 |
| e B     | 0.330 | 0.350     | 0.370 |
| θ °     | 0     | 7         | 15    |

UNIT: INCH



## **16.2 SOP28 PIN**



| Symbols    | MIN.  | MAX.  |
|------------|-------|-------|
| Α          | 0.093 | 0.104 |
| <b>A</b> 1 | 0.004 | 0.012 |
| D          | 0.697 | 0.713 |
| E          | 0.291 | 0.299 |
| Н          | 0.394 | 0.419 |
| L          | 0.016 | 0.050 |
| θ °        | 0     | 8     |

UNIT: INCH



## **16.3 SSOP 28 PIN**



| SYMBOLS  | MIN       | NOR    | MAX  | MIN     | NOR   | MAX   |  |
|----------|-----------|--------|------|---------|-------|-------|--|
| STWIBULS |           | (inch) |      | (mm)    |       |       |  |
| Α        | -         | -      | 0.08 | -       | -     | 2.13  |  |
| A1       | 0.00      | -      | 0.01 | 0.05    | _     | 0.25  |  |
| A2       | 0.06      | 0.07   | 0.07 | 1.63    | 1.75  | 1.88  |  |
| b        | 0.01      | -      | 0.01 | 0.22    | -     | 0.38  |  |
| С        | 0.00      | -      | 0.01 | 0.09    | _     | 0.20  |  |
| D        | 0.39      | 0.40   | 0.41 | 9.90    | 10.20 | 10.50 |  |
| E        | 0.29      | 0.31   | 0.32 | 7.40    | 7.80  | 8.20  |  |
| E1       | 0.20      | 0.21   | 0.22 | 5.00    | 5.30  | 5.60  |  |
| [e]      | 0.0259BSC |        |      | 0.65BSC |       |       |  |
| L        | 0.02      | 0.04   | 0.04 | 0.63    | 0.90  | 1.03  |  |
| R        | 0.00      | -      | -    | 0.09    | -     | -     |  |
| θ°       | 0°        | 4°     | 8°   | 0°      | 4°    | 8°    |  |



## 16.4 P-DIP 32 PIN



| SYMBOLS        | MIN.      | NOR.  | MAX.  |  |  |  |
|----------------|-----------|-------|-------|--|--|--|
| Α              | 1         | _     | 0.220 |  |  |  |
| A1             | 0.015     | _     | _     |  |  |  |
| A2             | 0.150     | 0.155 | 0.160 |  |  |  |
| D              | 1.645     | 1.650 | 1.660 |  |  |  |
| E              | 0.600 BSC |       |       |  |  |  |
| E1             | 0.540     | 0.545 | 0.550 |  |  |  |
| L              | 0.115     | 0.130 | 0.150 |  |  |  |
| e <sub>B</sub> | 0.630     | 0.650 | 0.670 |  |  |  |
| а              | 0         | 7     | 15    |  |  |  |

UNIT: INCH

### NOTE:

1.JEDEC OUTLINE : MS-011 AC



## 16.5 SOP 32 PIN



| SYMBOLS | MIN.  | MAX.  |
|---------|-------|-------|
| Α       | _     | 0.120 |
| A1      | 0.004 | 0.014 |
| D       | 0.799 | 0.815 |
| E       | 0.437 | 0.450 |
| Н       | 0.530 | 0.580 |
| L       | 0.016 | 0.050 |
| e°      | 0,    | 10'   |

UNIT: INCH

#### NOTE:

- 1.JEDEC GUTLINE:MO-099 AB
- 2.DATUM PLANE ⊞IS L≪ATED AT THE BOTTOM OF THE MOLD PARTING LINE COINCIDENT WITH WHERE THE LEAD EXITS THE BODY.
- 3.0 MENSIONS E AND D DO NOT INCLUDE MOLD PROTRUSION. ALLOWABLE PROTRUSION IS 10 MIL PER SIDE. DIMENSIONS E AND D DO INCLUDE MOLD MISMATCH AND ARE DETERMINED AT DATUM PLANE ED
- 4.DIMENSION 6 DOES NOT INCLUDE DAMBAR PROTRUSION.



## 16.6 P-DIP 40 PIN



| CVMDOLC   | MIN          | NOR   | MAX    | MIN    | NOR    | MAX    |  |
|-----------|--------------|-------|--------|--------|--------|--------|--|
| STIVIBULS | SYMBOLS (inc |       | (inch) |        | (mm)   |        |  |
| Α         | -            | -     | 0.220  | -      | -      | 5.588  |  |
| A1        | 0.015        | -     | -      | 0.381  | -      | -      |  |
| A2        | 0.150        | 0.115 | 0.160  | 3.810  | 2.921  | 4.064  |  |
| D         | 2.055        | 2.060 | 2.070  | 52.197 | 52.324 | 52.578 |  |
| Е         | 0.600        |       | 15.240 |        |        |        |  |
| E1        | 0.540        | 0.545 | 0.550  | 13.716 | 13.843 | 13.970 |  |
| L         | 0.115        | 0.130 | 0.150  | 2.921  | 3.302  | 3.810  |  |
| e B       | 0.630        | 0.650 | 0.067  | 16.002 | 16.510 | 1.702  |  |
| θ°        | 0°           | 7°    | 15°    | 0°     | 7°     | 15°    |  |



## 16.7 QFP 44 PIN



| 0)/44001.0 | MIN    | NOR   | MAX   | MIN    | NOR    | MAX    |
|------------|--------|-------|-------|--------|--------|--------|
| SYMBOLS    | (inch) |       | (mm)  |        |        |        |
| Α          | -      | -     | 0.106 | -      | -      | 2.700  |
| A1         | 0.010  | 0.012 | 0.014 | 0.250  | 0.300  | 0.350  |
| A2         | 0.075  | 0.079 | 0.087 | 1.900  | 2.000  | 2.200  |
| b          | 0.012  |       | 0.300 |        |        |        |
| С          | 0.004  | 0.006 | 0.008 | 0.100  | 0.150  | 0.200  |
| D          | 0.512  | 0.520 | 0.528 | 13.000 | 13.200 | 13.400 |
| D1         | 0.390  | 0.394 | 0.398 | 9.900  | 10.000 | 10.100 |
| Е          | 0.512  | 0.520 | 0.528 | 13.000 | 13.200 | 13.400 |
| E1         | 0.390  | 0.394 | 0.398 | 9.900  | 10.000 | 10.100 |
| L          | 0.029  | 0.035 | 0.037 | 0.730  | 0.880  | 0.930  |
| [e]        | 0.031  |       | 0.800 |        |        |        |
| θ°         | 0°     | -     | 7°    | 0°     | -      | 7°     |



## **16.8 SSOP 48 PIN**



| SYMBOLS  | MIN    | NOR   | MAX   | MIN    | NOR    | MAX    |
|----------|--------|-------|-------|--------|--------|--------|
| STWIBULS | (inch) |       |       | (mm)   |        |        |
| Α        | 0.095  | 0.102 | 0.110 | 2.413  | 2.591  | 2.794  |
| A1       | 0.008  | 0.012 | 0.016 | 0.203  | 0.305  | 0.406  |
| A2       | 0.089  | 0.094 | 0.099 | 2.261  | 2.388  | 2.515  |
| b        | 0.008  | 0.010 | 0.030 | 0.203  | 0.254  | 0.762  |
| С        | -      | 0.008 | -     | -      | 0.203  | -      |
| D        | 0.620  | 0.625 | 0.630 | 15.748 | 15.875 | 16.002 |
| E        | 0.291  | 0.295 | 0.299 | 7.391  | 7.493  | 7.595  |
| [e]      | -      | 0.025 | -     | -      | 0.635  | -      |
| He       | 0.396  | 0.406 | 0.416 | 10.058 | 10.312 | 10.566 |
| L        | 0.020  | 0.030 | 0.040 | 0.508  | 0.762  | 1.016  |
| L1       | -      | 0.056 | -     | -      | 1.422  | -      |
| Y        | -      | -     | 0.003 | -      | -      | 0.076  |
| θ°       | 0°     | -     | 8°    | 0°     | -      | 8°     |



# **16.9 LQFP 48 PIN**



| SYMBOLS    | MIN NOR MAX |        |      |  |  |
|------------|-------------|--------|------|--|--|
| SYMBOLS    | (mm)        |        |      |  |  |
| Α          | 1.6         |        |      |  |  |
| <b>A</b> 1 | 0.05        | -      | 0.15 |  |  |
| A2         | 1.35        | -      | 1.45 |  |  |
| с1         | 0.09        | 0.16   |      |  |  |
| D          | 9.00 BSC    |        |      |  |  |
| D1         | 7.00 BSC    |        |      |  |  |
| E          | 9.00 BSC    |        |      |  |  |
| E1         | 7.00 BSC    |        |      |  |  |
| е          | 0.5 BSC     |        |      |  |  |
| В          | 0.17        | 0.17 - |      |  |  |
| L          | 0.45        | -      | 0.75 |  |  |
| L1         | 1 REF       |        |      |  |  |



# 17 单片机正印命名规则

## 17.1 概述

SONiX 8 位单片机产品具有多种型号,本章将给出所有 8 位单片机分类命名规则,适用于空片 OTP 型单片机。

## 17.2 单片机型号说明



### 17.3 命名举例

| 名称          | ROM 类型 | 器件(Device) | 封装形式  | 温度范围   | 封装材料                  |
|-------------|--------|------------|-------|--------|-----------------------|
| SN8P2708APB | OTP    | 2708A      | P-DIP | 0℃~70℃ | 无铅封装(PB-Free Package) |
| SN8P2708AXB | OTP    | 2708A      | SSOP  | 0℃~70℃ | 无铅封装(PB-Free Package) |



# 17.4 日期码规则







SONiX 公司保留对以下所有产品在可靠性,功能和设计方面的改进作进一步说明的权利。SONiX 不承担由本手册所涉及的产品或电路的运用和使用所引起的任何责任,SONiX 的产品不是专门设计来应用于外科植入、生命维持和任何 SONiX 产品的故障会对个体造成伤害甚至死亡的领域。如果将 SONiX 的产品应用于上述领域,即使这些是由 SONiX 在产品设计和制造上的疏忽引起的,用户应赔偿所有费用、损失、合理的人身伤害或死亡所直接或间接产生的律师费用,并且用户保证 SONiX 及其雇员、子公司、分支机构和销售商与上述事宜无关。

### 总公司:

地址: 台湾新竹县竹北市台元街 36 号 10 楼之一

电话: 886-3-5600-888 传真: 886-3-5600-889

#### <u>台北办事处:</u>

地址: 台北市松德路 171号 15楼之 2

电话: 886-2-2759 1980 传真: 886-2-2759 8180

#### <u>香港办事处:</u>

地址:香港新界沙田沙田乡宁会路 138 # 新城市中央广场第一座 7

楼 705 室

电话: 852-2723 8086 传真: 852-2723 9179

### 松翰科技(深圳)有限公司

地址:深圳市南山区高新技术产业园南区 T2-B 栋 2 层

电话: 86-755-2671 9666 传真: 86-755-2671 9786

### <u>技术支持</u>:

Sn8fae@SONiX.com.tw